# BEST AVAILABLE COPY

### PATENT SPECIFICATION

1 496 780 (11)

(21) Application No. 54623/74

(22) Filed 18 Dec. 1974

(31) Convention Application No. 425760

(32) Filed 18 Dec. 1973 in

(33) United States of America (US)

(44) Complete Specification published 5 Jan. 1978

(51) INT CL<sup>2</sup> G06F 3/00

(52) Index at acceptance

G4A 10EX 12P 13E 13M 17P 3W2 6G 6H FG

(72) Inventors JOHN A. RECKS FRANK V. CASSARINO JR. EDWARD F. GETSON JR. KARL F. LAUBSCHER ALBERT T. McLAUGHLIN and EDWIN J. PINHEIRO



#### (54) MICRO-PROGRAMMED PROCESSOR

(71) We, HONEYWELL INFORMA-TION SYSTEMS INC., a Corporation organised and existing under the laws of the State of Delaware, United States of 5 America, of 200 Smith Street, Waltham, Massachusetts 02154, United States of America, do hereby declare the invention, for which we pray that a patent may be granted to us, and the method by which it is 10 to be performed to be particularly described in and by the following statement:-

This invention relates to apparatus for interconnecting a plurality of peripheral 15 devices to communicate with a data processing system. More specifically, the present invention relates to peripheral controllers which provide an appropriate interface for a plurality of mass storage 20 devices, such as disc devices.

In order to provide greater efficiency in processing input/output operations, the burden of controlling input/output operations has been shifted to the 25 peripheral controllers. This in turn has increased greatly the complexity of such controllers particularly where the controllers are required to handle data transfer operations involving devices 30 having a variety of different operating characteristics. In order to reduce the cost of such controllers, many systems employ microprogramming. In general, the controllers have utilized general purpose 35 microprocessors with tailored microprograms for different types of devices.

An important disadvantage of the above approach is that the speed of the data 40 transfer operations performed by the microprogrammed peripheral controller is limited by the processing speed of the controller's microprocessor. Thus in order to provide reasonably efficient transfer

rates, the microprocessor is required to operate at fast rates in order to provide the necessary transfer and control signals comparable with the processing rates of the devices. This in turn can increase greatly the cost of the peripheral controller. Moreover, when the system is required to handle faster input/output devices, this normally necessitates a complete redesign of the microprocessor.

Accordingly the invention provides a microprogrammed peripheral processor having a peripheral subsystem interface to which a central processor may be coupled and at least one device level interface to which an input/output device may be coupled, and operative to control the operation of the input/output device in response to command signals received through the peripheral subsystem interface and to transfer information between the peripheral subsystem interface and the device level interface, the peripheral processor comprising:

unitary microprogram control means including storage means storing a plurality of microinstruction sequences each having a plurality of microinstructions, branch control means responsive to a command code and other signals to cause the storage means to branch among said sequences, and decoding means generating control signals in response to the micro-instructions read out from the storage means;

bidirectional data transfer means coupled to the peripheral subsystem interface and the device level interface; and

sequence control means responsive to the control signals to generate signals controlling the transfer of information signals from one of the interfaces through the data transfer means to the other interface at a rate independent of the operating rate of the microprogram control

50

means when a microinstruction sequence for such data transfer is entered.

An embodiment of the invention will now be described, by way of example, with reference to the accompanying drawings, in which.

Figure 1 is a diagrammatic illustration of a data processing system.

Figure 2 shows in greater detail the 10 peripheral processor 300 of Figure 1.

Figure 3a shows in greater detail the PSI

controls area of Figure 2. Figure 3b shows in greater detail the Data Buffer Registers and Control Area

15 302-50 of Figure 2. Figure 3c shows in greater detail the

control sequence storage of section 308 of

Figure 3d shows in greater detail the counter controls of section 308 of Figure 2.

Figure 3e shows in block form the read only storage controls section 304 of Figure

Figure 3f shows in greater detail the 25 different branch circuits of Figure 3e.

Figure 3g shows in greater detail various portions of the Read Write Buffer Storage Section 306 of Figure 2.

Figure 3h shows in greater detail the 30 control logic circuits 306-70 and toggle 1 increment circuits 306—100 of section 306 of Figure 3g.

Figure 3i shows in greater detail the ALU

section 316 of Figure 2.

35

Figure 3j shows in greater detail the data and counter section 318 of Figure 2.

Figure 3k shows in greater detail the adapter and device line controls section 310 of Figure 2.

Figures 4a through 4g shows the different microinstruction formats executed by the processor.

Figures 5a and 5b show the format of the records stored on the mass storage devices.

Figures 6a through 6c are flow diagrams used in describing the operation of the processor.

Introductory Summary

A microprogram peripheral processor includes a control store containing a number of microprograms for processing commands issued by a data processing unit and one of a number of peripheral devices. The peripheral processor also includes 55 control sequencing hardware apparatus which is arranged to be conditioned by microinstructions from the control store in response to the command issued. Upon being so conditioned, the hardware 60 apparatus sets up the various data transfer paths between a designated peripheral device and a channel. Thereafter, the transfer proceeds under the control of the hardware apparatus at a maximum rate.

During the data transfer, the microprogram processor idles or performs operations independent of the data transfer until it receives a signal from the hardware apparatus indicating a completion of the transfer operation. Upon receipt of the signal, the control processing is again transferred back to the microprogrammed processor.

Thus, the arrangement is such that the data transfer can proceed independently of the processing rate of the microprogrammed processor. That is, the arrangement obviates the need for requiring the microprogrammed processor to execute a number of microinstructions for either transferring or comparing bytes as required by the commands issued to the processor. Additionally, the arrangement eliminates the necessity for having to introduce into the peripheral processor additional hardware duplicating operations which are also provided for by microprograms normally included within a general purpose microprocessor. Hence, the arrangement reduces costs to a minimum by reducing the amount of duplication or redundancy which results from the utilization of a general purpose microprocessor. Moreover, by reducing duplication, the arrangement achieves high reliability.

> General Description of Overall System of Figure 1

The present system finds application primarily in a data processing system which 100 includes an input/output subsystem in which a peripheral processor controls the operation of a plurality of a peripheral devices in response to commands received from an input/output channel. This type of system can for the purposes of the present invention be considered conventional in design. Therefore, the system will be described only to a limited extent.

Also, for ease of reference, definitions of certain terms used herein are summarized in an appendix.

Referring now to Figure 1, there is shown system which incorporates a microprogrammable peripheral processor. The system includes a central processor complex (CPC) which includes those units used for addressing main storage for retrieving or storing information for performing arithmetic and logical operations upon data, for sequencing instructions in the order desired and for initiating communications between main storage and external devices. The main units of the central processor complex 100 includes a central processing unit (CPU) 101-2, a main memory subsystem 104 and

70

75

STK V. EMC STK 03054

.

7

an input/output controller (IOC) 101—6. The CPU executes instructions of one or more programs stored in the main storage subsystem 104. The IOC is that part of the system involved in the execution of commands used to carry out an input/output operation. An input/output operation is defined by a channel program. The program includes a plurality of instructions called commands. The operation is executed by a "channel". The channel includes the IO facilities, a hardware link between the IOC and peripheral processor termed a physical channel, and a logical channel. The logical

channel is a collection of facilities in a peripheral processor which is required to execute an I/O operation defined by a channel program.

A peripheral subsystem interface (PSI) 200 provides a transfer and control link for exchanging information between a mass storage peripheral processor 300 and the IOC 106. The exchange is accomplished by controlling the logical states of various signal lines in accordance with pre-established rules implemented through a sequence of signals termed "dialog". The interface includes the lines listed, with their functions, below:

2,5

30

#### Peripheral Subsystem Interface Lines

1,496.780

|    | •           | Lilles                                                                                                                                                                                                                                                                                                                                             |
|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | Designation | Description                                                                                                                                                                                                                                                                                                                                        |
| 35 | DO—7        | The Data path lines are a one byte wide bidirectional path (eight bits+parity, not shown) that extends between the MSP 300 and the IOC. The nature of the information on the data lines (i.e. data, service code, etc.) is determined by the dialog.                                                                                               |
| 40 | SCI         | The Service Code In line extends from the MSP to the IOC. When set, SCI indicates that the MSP has a service code sequence to send to the IOC. This line is fully interlocked with a Service Enable out line. The MSP only transfers the service code sequence when the SEO line is high. The SCI line becomes high only when the SEO line is low. |
| 45 | SEO         | The Service Enable Out line extends from the IOC to the MSP and indicates when the IOC is ready to receive a service code sequence. The line is fully interlocked with the SCI line.                                                                                                                                                               |
|    | OPI :       | The OPerational In line extends from the MSP to the IOC. This line indicates the operational state of the MSP to the IOC. When activated, the OPI line indicates that the MSP is                                                                                                                                                                   |
| 50 |             | operational and capable of communicating with the IOC. When deactivated, it means that the MSP is powered down or is in a state that makes it incapable of responding to signals on the PSI.                                                                                                                                                       |
| 55 | OPO         | The OPerational Out line extends from the IOC to the MSP. This line indicates the state of the IOC. When activated, it indicates that the IOC is operational and capable of communication with the MSP. When deactivated, it signals that the IOC is powered down or is in a state that makes it                                                   |
| 60 | STI         | incapable of responding on the PSI.  The STrobe In line extends from the MSP to the IOC. This line in conjunction with a strobe out line controls data transfers on the interface. For a read operation (i.e. data from the MSP), the STI line can only be set when the STO/TMO is reset. The                                                      |
| 65 |             | STI line indicates to the IOC that data is present on the data lines. To obtain data the IOC responds by setting either the STO line or TMO line which resets the STI line. When the IOC detects the fall of the STI line, it takes the data from the lines.                                                                                       |
| 70 |             | For a write operation, the roles of lines STO and STI are reversed. The IOC raises line STO when it puts data on the data lines. When the MSP detects the rise of line STO and it is ready to receive the data, it raises either line STI or line TMI. When the MSP detects the fall of line STO, it takes the                                     |
| 75 | STO         | data from the data lines.  The STrobe Out line extends from the IOC to the MSP. This line is used by the IOC to indicate its participation in the dialog on the interface.                                                                                                                                                                         |

15

20

25

30

35

40

45

50

55

60

**TMO** 

#### Peripheral Subsystem Interface Lines

#### Description (cont) For a read operation, STO is raised by the IOC when it detects Designation (cont) the rise of STI (or TMI) and it is ready to obtain the data. On a read operation, STO cannot be raised if STI and TMI are both logical ZERO. When the MSP detects the rise of STO, it lowers STI (or TMI). Upon detecting the fall of STI (or TMI), the IOC takes the data from the data lines. If necessary, the IOC can hold up the dialog at this point by delaying the fall of STO. When it is ready to proceed, it lowers STO, indicating to the MSP that the data has been taken and that the data lines can now be altered. If the IOC terminates the current dialog, it will do so by raising the TMO instead of STO for the last byte to be transferred. For a write operation, the STO line indicates to the MSP that the IOC has data ready for it. The IOC puts the data on the data lines and raises STO. The STO line may not be activated for a write operation unless the STI and TMI lines are reset. The STO line must be reset when STI (or TMI) is activated. When the MSP detects the fall of STO, it may then take the data. If necessary, the MSP can hold up the dialog at this point by delaying the lowering of STI (or TMI). When ready, the MSP lowers STI (or TMI) indicating to the IOC that the data lines can be now altered. The TerMinate Out line extends from the IOC to the MSP. This line is used by the IOC to end the current dialog. For a write operation, TMO can indicate one of the following conditions: (1) For a data transfer, TMO implies that a byte being transferred is the last byte of a field and the data count is exhausted. Since data chaining is transparent to the MSP, TMO rises only when the count of the last data chained CCE in the data chain array is exhausted. (2) For a command or IOC instruction transfer, TMO indicates that the transfer is complete with a byte being sent on the current transfer and that no more bytes are forthcoming. During a write operation, TMO can only rise if STI and TMI are low, and will fall when the IOC detects the rise of STI (or For a read operation, TMO is used in one of the following ways: (1) In a data transfer, TMO indicates that a byte being transferred exhausts the data count. Since data chaining is transparent to the MSP, TMO will only rise when the count associated with the last data chained CCE of the data chain array is exhausted. (2) In a service code sequence, TMO will be used in one of the following ways: 1. The IOC may raise TMO to stop the transfer of the sequence immediately (e.g. after detecting an error); 2. The IOC has received the maximum number of status bytes it can handle and the MSP is to stop any further transmission of status bytes in this service code sequence. In a read operation, TMO will be used in one of the above ways by being sent instead of STO. During a read operation TMO can only rise if STI (or TMI) is high, and will fall when STI (or TMI) falls. This line must be reset to a logical ZERO state when not in use.

The TerMinate In line extends from the MSP to the IOC. This line is used by the MSP to end current dialog. For a write operation, TMI is sent instead of STI and can indicate

one of the following conditions:

DIN

SRI

65

# Peripheral Subsystem Interface

|    |                                                                                                                                             | Lines                                                                                                                                                                                                                                                                                             |    |
|----|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|    | Designation (cont)                                                                                                                          | Description (cont)                                                                                                                                                                                                                                                                                |    |
| 5  | TMI (cont)                                                                                                                                  | 1. For a data transfer, TMI indicates that a byte being received is the last byte the MSP will accept for this transfer sequence (e.g., media is exhausted), or that the MSP is temporarily suspending the data transfer sequence.                                                                |    |
| 10 |                                                                                                                                             | <ol> <li>For a command transfer, TMI indicates that a byte being received is the last byte required by the MSP.</li> <li>For a read operation, TMI is sent instead of STI and indicates one of the following conditions:</li> <li>For a data transfer, TMI indicates that a byte being</li> </ol> |    |
| 15 |                                                                                                                                             | transferred is the last byte available from the medium for<br>this data transfer sequence, or that the MSP is temporarily<br>suspending the data transfer sequence. The suspended<br>sequence may be resumed by using the service code<br>"Initiate Data Transfer—Resume". However, it is         |    |
| 20 |                                                                                                                                             | command Pointer movement (for this same logical channel) will indicate termination of the data transfer (cannot be resumed), since the Move Pointer service code implies that execution of the CCE is complete. Thus, if the                                                                      | ٠  |
| 25 |                                                                                                                                             | MSP intends to resume a data transfer that it is suspending, it should not send any Move Pointer service codes for that logical channel until after the transfer is resumed.                                                                                                                      |    |
| 30 |                                                                                                                                             | <ol> <li>For a service code sequence, TMI indicates that the byte(s) being transferred is the last byte in the service code sequence.</li> <li>TMI must be set to logical ZERO when not in use.</li> </ol>                                                                                        |    |
| 35 | As seen from Figur capable of controlli physical channels de 200—n which connect a number of peripher 300—n. Each periexchanges information | ng a plurality of signated 200—1 to the IOC with one of all processors 300 to pheral processor and table:  level interface (DLI) according to specific dialog sequences. The various lines which comprise the device level interface and descriptions are set forth in the following table:       | 40 |
|    |                                                                                                                                             | Device Level Interface Lines                                                                                                                                                                                                                                                                      |    |
| 45 | Designation                                                                                                                                 | Description                                                                                                                                                                                                                                                                                       |    |
|    | DCP, DC0—DC5                                                                                                                                | The command code lines carry encoded commands from the mass storage processor (MSP) to the mass storage device (MSD) for decoding and execution.                                                                                                                                                  |    |
| 50 | D10—D17                                                                                                                                     | The nine bidirectional line (including parity, not shown) are used to transfer data, address, control and status information between the MSP and a MSD.                                                                                                                                           |    |
|    | DCS                                                                                                                                         | A Device Command Strobe line when at a logical ONE signals when the signals on the command codes lines are valid for sampling.                                                                                                                                                                    |    |
| 55 | OPI                                                                                                                                         | An Operational In line which signals that the MSD is existent, powered up and capable of communication with the MSP.                                                                                                                                                                              |    |
|    | IDX                                                                                                                                         | An index mark line when at a logical ONE for 2 microseconds                                                                                                                                                                                                                                       |    |
|    | OPO                                                                                                                                         | indicates the beginning of a logical track.  An operational out line which signals that the MSP is existent,                                                                                                                                                                                      |    |
| 60 |                                                                                                                                             | powered up and capable of communication with the MSD.                                                                                                                                                                                                                                             |    |

powered up and capable of communication with the MSD. A device initialize line which causes a MSD to place all its storage

A serial read in line which during a write operation signals the MSP that the MSD is executing a write command. The MSD

elements in an initialized state.

activates this line upon receipt of a write command and does not reset it until the trailing edge of DCS. During a read

### Device Level Interface Lines

Designation (cont) SRI (cont.)

Description (cont)

5

operation, this line contains the information read from the media. The read signal is produced by the heads, amplified and converted into digital form before applied to the SRI line. It contains a pulse for each transition recorded on the medium. This line is also used as a strobe to control interface dialog when information is transmitted over the bidirectional data lines.

SWO 10

A serial write out line which transmits the information to be written. It contains a single logical ONE pulse for each transition to be recorded on the medium. This line is also used as a strobe to control interface dialog when information is transmitted over the bidirectional data lines.

The device level interface provides for the exchange of data and control information between a peripheral processor and connected peripheral devices. It will be obvious that the interface lines are only common to a specific type of device. The specific interface disclosed connects a mass storage device 500 to the mass storage peripheral processor 300 as shown in Figure 1. Just as the IOC 101-6 is capable of exchanging data and control information between a plurality of peripheral processors, each peripheral processor can exchange data and control information and

between it and a plurality of peripheral 30 devices. For simplicity, only a single peripheral device is illustrated as being connected to each peripheral processor of Figure 1.

Continuing on with the general 35 description of Figure 1, it is seen that the memory subsystem 104 includes a memory interface unit 104—2 and a main memory 104-4. As shown, the main memory subsystem can have from 1 to 4 memory 40 ports, each port providing a storage capacity of 256 kilobytes. The memory interface unit 104-2 includes the logic and control circuits required for establishing communication between a memory port 45 and the CPU and IOC, these units being conventional. The main memory subsystem 104-4 utilizes a MOS semiconductor memory. As seen from Figure 1, the main memory subsystem comprises 1 to 4 main

shown. In the processor itself, a memory port connects a memory unit. Each main 55 memory unit includes a memory controller or main store sequencing unit and up to 8 memory subunits. Each subunit includes 4 sections, each of which includes a 8K by 10 bit memory array. Each main memory

50 memory units each coupled with the

processor subsystem via a corresponding one of the cables 104-6 to 104-9 as

60 controller is operative to perform the necessary read/write memory operations required for accessing a word of information which comprises four 9 bit bytes of information.

Before beginning a description of the invention utilized in the mass storage processor 300 of Figure 1, first a discussion of the manner in which information appears on a storage system with which the present system is used will be given.

Information is generally stored along circumferential tracks on a rotating device such as a disk, in records comprising a number of information fields. These fields include a count field, a key field and a data field. Normally, an index mark indicates the physical beginning of each track and all tracks on a disk pack are synchronized by the same index mark. Each track is headed by a home address field for address identification and a track descriptor record (record R0) for indicating the physical condition of the track. The fields of information recorded on a track are separated by gaps. The gap lengths vary depending upon the storage device, location within the record, format, bit density and the record length

An address marker indicates the peginning of each record for control purposes. Each address marker is preceded by a synchronization area which includes a plurality of synchronization signals used to synchronize the timing circuits used in the performance of a read operation. The various terms defined above are also given in a glossary of terms section in the appendix. The significance of these fields will be described later in connection with

Figures 5a and 5b.

General Description of Mass Storage Processor 300

Figure 2 is a more detailed diagram of the peripheral processor.

Referring to the Figure, it is seen that the 105 major sections of the processor 300 include: Peripheral Subsystem Interface (PSI) Controls Section 302; a General Purpose Register section 314; an Arithmetic and Logic Unit (ALU) section 316; a Read Only 110 Storage Control section 304; a High Speed Sequence Controls section 308; a Device Level Interface (DLI) Controls section 310;

70

a Read Write Buffer Storage (RWS) section 306; and a Counter section 318.

The PSI controls section 302 includes logic circuits and buffer registers necessary to connect the processor with the one byte wide asynchronous PSI interface 200 and to sustain the required data and control dialog necessary for communication with the IOC As seen from Figure 2, this section is 10 coupled to the various sections for receiving data and control signals via transfer conductor paths 303—1 to 303—5. The section 302 is divided into two areas: a PSI control area 302—1 and a buffer register and control area 302-50, described in greater detail later. The ALU section 316 in addition to being coupled to the Buffer section 302-50 is also coupled to the Buffer Storage section 306 and General Purpose Registers section 314 via paths 303-5 and 303-6 respectively. The ALU section 316 performs all logic, arithmetic and register transfers within the processor. The various modes of operation 25 for the ALU are established by signals applied via conductor path 303—9 from the read only storage controls section 304. As described in greater detail later, the section 316 includes a pair of identical arithmetic and logic units, conventional in design. designated as a main ALU and an auxiliary ALU, and their associated control and error checking logic circuits. Both ALUs are constructed of two 4 bit MSI ALUs which are interconnected to produce an 8 bit output. Depending upon the states of the input signals applied to the carry enable, carry in and mode control input terminals of the ALUs, the ALUs can be 40 made to perform 16 logic or 32 different arithmetic operations upon the pair of operands being operated upon. Both ALUs operate upon the same operands simultaneously and the error checking circuits compare the results of both ALUs. The general purpose registers section 314 includes 16 8-bit-wide general purpose registers and provides storage for information required during a particular operation (e.g. command codes, ALU operands etc.). Additionally, the section includes 16 8-input multiplexer-selector circuits, conventional in design, from which the contents of any one of 8 other sources 55 can be applied to the ALUs as one of the operands. The general purpose registers are storage locations of an addressable solid state scratch pad memory, conventional in design. The registers are addressable by the 60 control store section 304 and the buffer storage section 306 via paths 303-8 and 309—12 respectively.

The gap and data counter section 318 is also coupled to the ALU section 316 via conductor path 303—10. This section

includes data counter logic circuits and gap counter circuits which provide primary count control during read, write and search operations. The data counter circuits provide a count of the number of bytes being operated upon. The gap count logic circuits provide orientation information by giving an accurate indication of the gap length between fields of a data record being read (e.g. the gap length between the header and key fields, the gap length between the key and data field, etc.). Each of the two counters, as explained in greater detail later, includes a main and an auxiliary counter, together with decrementing and checking logic circuits. Each counter is constructed of 4 synchronous 4 bit binary counter chips which are connected to form a 16 bit counter. Both counters of the data counter are loaded by a microinstruction with the same count specified by the contents of either the ROSLR or RWSLR. Both counters are decremented and the states of both counters are compared by error checking circuits. When the circuits detect a non comparison, they cause an error indication to be set. Similarly, both counters of the gap counter are loaded via the ALU section 316 with same count derived from a constant field of a microinstruction. When enabled, the counters are decremented by clock pulse signals from a clock 308—2 (i.e. the counter is decremented by 1 every 600 ns). Error checking circuits check the counters for proper operation in the same manner as the operation of the data counter is checked.

The read only storage controls section 304 provides storage for resident control and diagnostic microprograms (i.e. 4K 32-bit words of storage). The section, as described in greater detail later, has a control store which includes two sections. One section is used for native operations and the other section is used for emulation of foreign systems. The control store is unalterable and is constructed of programmable read only memory (PROM) chips, conventional in design. (Obviously, 115 the control store could be constructed of random access memory (RAM) chips, conventional in design. Thus it could be loaded with microinstructions by external means, such as a tape cassette device).

The section 304 also includes associated addressing, control, decoding and parity logic circuits. Additional address storage circuits are included to enable branching between three levels of microinstruction 125 subroutines.

The read/write storage section 306 is coupled via conductor paths 303—1, 303—5 and 303—12 to the other sections as shown in Figure 2. This section includes a 130

25

30

35

read/write alterable storage of 1.5K 10-bit locations used for storing device parameter bytes in addition to providing temporary storage for control and data handling operations (e.g. status and address information).

The Device Level Interface Controls section 310 includes an integrated control adapter designated as block 310-2 which is 10 coupled to paths 310-4 and 400. The adapter includes logic circuits and buffer registers required to establish an interface with disk storage devices of the system for controlling device operations and 15 generating required dialogue sequences over the bus 400. That is, the section enables the selection of the designated disk device and execution of the various commands. The buffer registers provide an interface between the asynchronous operated device/adapter circuits and the synchronous operated mass storage processor logic circuits.

#### Detailed Description of Mass Storage Processor Sections

Now, the above described sections will be described in greater detail with reference to Figures 3a to 3k.

#### PSI Controls Section 302 and Buffer Section 302—50

The PSI Control Area 302 and Buffer Register and Control Area 302-50 are shown in greater detail in Figures 3a and 3b respectively.

Referring to Figure 3a, it is seen that this area includes a plurality of receiver/driver logic circuits 302—3 which operate to provide digital control and data signals to interface 200. The receiver/driver circuits each comprise a pair of differential amplifier circuits.

As seen from Figure 3a, a read buffer 302-14 and a write buffer transfer information between the interface driver circuits and receiver circuits and the data buffers of the buffer section 302-50.

The read buffer 302-14 includes a plurality of amplifier latching circuits, conventional in design. During read 50 operations, the output signals from the A Buffer of section 302—50 applied via a bus 302-16 are loaded into the read buffer 302—14 when a control signal PAATP10 is switched to a binary ONE. As explained herein, this signal is generated by asynchronous circuits included in this block 302-4. Briefly, this block includes a plurality of latching amplifier circuits capable of being set and reset by the IOC via signals applied to various lines of the interface 200. For example, the asynchronous logic circuits signal the IOC of data stored in the read buffer by setting

lines STI or TMI. The read buffer 302-14 stores bytes until the IOC resets one of the lines STO or TMO which in turn resets corresponding ones of the latching circuits.

1,496,780

The write buffer 302-12 includes a plurality of register stages, conventional in design. The buffer 302—12 receives input signals which are stored in the buffer in response to an output Data Valid'signal PAODVIO being switched to a binary ONE. This signal is generated by asynchronous logic circuits when the IOC forces strobe output signal PISTO10 from a binary ONE to a binary ZERO. The contents of the write buffer are selectively loaded into the A. E or F buffers as a function of their availability in section 302-50 by control signals generated by control circuits 302-70 and 302-72 in response to signal PAPRF10.

The PSI control area 302-1 also includes synchronous control logic circuits included within 302—12. The synchronous control circuits include a plurality of flipflops settable by micro-operation signals from the read only storage controls section 304 applied via an input bus 303—5, Figure 2. Also, the circuits can be set from signals applied via interface 200. For example, the micro-operation signals can initiate activity on the peripheral subsystem interface 200 by setting one of the three sequence flipflops included in this section. That is, a microinstruction can cause a setting of a request data flip-flop, ROD, conditioning the interface 200 to receive data bytes from the IOC. Also, micro-operation signals 100 from another instruction can cause a ' data transfer" flip-flop, DDT, to condition the interface 200 to transfer data bytes to the IOC. Another microinstruction can produce micro-operation signals which 105 condition a do service code flip-flop, DSC, to condition the interface 200 for signaling a transfer of service code or command information to the IOC. The other flip-flops include a terminate flip-flop, TRM, a 110 service code in flip-flop, SCI, a service enable out flip-flop, SEO, an operational out flip-flop, OPO, and an operational in flip-flop, OPI, some of which are also set and reset by micro-operations signals for 115 controlling the transfer of command and data bytes via interface 200. The operation of these flip-flops will be described in greater detail as necessary later.

Each of the flip-flops included within the 120 synchronous control section 302-12 receives PDA clocking signals from a central clock or timing source 308-2 included in section 308.

It is also seen that section-302-1 125 includes a two byte or sixteen bit decrementing counter which includes four 4-bit binary counter stages, conventional in

design. This counter is used by the asynchronous control logic circuits of block 302-4 to determine when a terminate in flip-flop TMI is to be set. An auxiliary counter 302-10 is also included to enable compare circuits of block 302—8 to detect the occurrence of a counter failure. That is, the auxiliary counter 302—10 and main counter 302-6 are both loaded in response to an I/O microinstruction from the same source (e.g. through the ALU section 318 from either the control store of section 304 or buffer storage of section 306) and both are decremented by a clocking signal PCCLK10 from the circuits of control 302-1. The compare circuits of block 302-8 check to determine whether both counters are at the same state when one of the counters has been decremented to zero. If they are not, the circuits cause the setting of an error indication. When both counters have been decremented to zero, the circuits of block 302-8 switch a "count equal zero" signal PCCE020 to a binary ZERO. This indicates that the required number of bytes have been transferred (i.e. no error indicated).

From Figure 3b, it is seen that area 302—50 includes six registers 302—52 to 302—57, herein referred to as registers A to F, and associated control logic circuits included within blocks 302-70 and 302-72. Each register includes 11 stages: 9 for storing the 8 data bits and parity bit of a byte, I for storing a marker or register full indicator bit and I for storing a terminate out indicator bit. Data and control information bytes are transferred between the read and write buffers of area 302-1 and a write multiplexer circuit and a read buffer, parallel by bit or byte serial. The direction of transfer and path is determined by the states of flip-flops included within the High Speed Sequence Controls section 308. As explained herein, these flip-flops are preset to certain states by microinstructions and the input signals applied by the flip-flops to the circuits of the control blocks 302-70 and 302-72 condition the circuits for such transfers.

The types of modes of operation which can be specified are as follows. The first mode (a no sequence active mode—NSA) represents the static state of the processor in which no data transfers to/from the disk units or to/from the IOC take place. The circuits of block 302-70 and 302-72 are conditioned such that registers 302-52, 302-53 and 302-54 (A, B and C) are operatively coupled to the PSI and registers D. E and F are operatively coupled to the device adapter 310-2. The states of a pair of signals CQTXIIO and CQTX010 generated by a Transfer In flip-flop and a Transfer Out flip-flop included in the

sequence control circuits establish the direction of byte transfers for the groups of registers A to C and D to F. For example, the directions of transfer for the states of these signals is as follows:

(1) CQTXI00(1)=PSI→ REG. A→ reg. B→ reg. C→ wait for processor (firmware) action:

(2) CQTXII0(1)=reg. C→ reg. B→ reg. A→ wait for PSI action:

(3) CQTX000<sup>(1)</sup>=Device Adapter→ reg.  $F \rightarrow reg. E \rightarrow reg. D \rightarrow wait for processor$ (firmware) action: and

(4) CQTX010(1)=reg. D→ reg. E→ reg. F→ raise request line- wait for Device Adapter action.

Other modes, submodes, are derived by utilizing the states of these two signals as follows:

1. CQTXI00 & CQTX000—Normal state of the processor. In this mode, bytes are transferred from the PSI and/or

device adapter into the processor.

2. CQTX100 & CQTX010—In this mode, control information bytes are transferred to the device adapter and/or device.

3. CQTXIIO & CQTX000—In this mode, information such as service code bytes and status bytes is transferred to the IOC.

4. CQTXIIO & CQTX0I0—In this mode, the transfers of modes 2 and 3 are combined.

Another mode is a write operation mode which is established by the state of a control signal CQWT010 generated by a write operation sequence flip-flop included in the sequence control circuits. When signal CQWT010 is switched to a binary ONE, it forces signal CQTX010 and CQTX100 to a binary ONE and a binary ZERO respectively. These signals condition the registers to transfer bytes from the PSI to the device adapter or to the read/write store 110

The next mode is a read mode of operation which is established by the state of a signal CQRD010 generated by a Read Operation sequence flip-flop included in 115 the sequence control circuits. The signal CQRD010 together with signal PADDT10 from PSI control area 302-1 causes the signals CQTX110 and CQTX000 to be switched to a binary ONE and a binary 120 ZERO respectively. This allows bytes to be shifted from the device adapter through registers 302—57 to 302—52 to the PSI.

A further mode is a search operation mode which is established by the state of a 125 signal CQSH010 generated by a search

70

75

80

95

STK 03061

55

operation sequence flip-flop included in the sequence control circuits. The signal CQSH010 conditions the RWS section during search operations allowing bytes transferred through the registers from the device adapter or the PSI to the ALU section 316 to be written into the read/write storage section 306.

The control blocks 302—70 and 302—72 as seen from Figure 3b generate the signals required to transfer bytes between registers at the appropriate time (i.e. when the registers are empty). The signals shown are generated in accordance with the following 15 Boolean expressions:

#### 1. CDPTA10=CQTXI00 · CDPTE00 · CDPTF00 · PAPRF30 · CDARF00.

This is a PSI to A register transfer signal which is forced high when the Transfer In flip-flop is in a reset state (i.e. signal CQTX100=1), there is no transfer from the PSI to either the E or F registers (i.e. signals CDPTE00 and CDPTF00=1), the A register is not full (i.e. signal CDARF00=1) and the write register is full (i.e. signal PAPRF30=1).

#### 2. PAPRF10=PKVSP10 · PAOVD10+ PAPRFIO - PKVSPIO - CDPTX20.

This is the register full indicator for the PSI write register which sets whenever PAODVIO comes high and there is a valid sequence in progress (i.e. PKVSP10=1). This indicator resets when PTX comes high which transfers the contents of the write register into the A, E or F registers.

#### 3. PAATP10=((PKDSC00 PKVSP10+ PKSEOIA PKVSPIO) PKSTO20 -PKTM020 - PKADV10 - PKSTI20 -PKTMI20 · PKDDT10]+PAATPI0 · PKVSP10 - CDARF00.

This is a transfer contents of A register into the PSI read register. It comes high only during read operations (i.e. data transfers to the IOC). It comes high whenever the PSI is in a read mode (i.e. PKDDT10 signal), there is no strobe cycle in progress, the sequence is valid, the PSI counter is other than zero and there is a valid byte in the A register (i.e. signal PKADV10=1). It stays set long enough to insure that signals PKSTI10, PKTMI10 and PKATP30 are set and the full indicator for the A register is reset (i.e. CDARF00=1).

#### CDATB10=CQTXI00 CDBRF00+CDBTC10.

The A register to B register transfer signal comes high when input transfer signal (CQTX100 is a ZERO and the B register is empty (i.e. signal CDBRF00=1). 60 It also comes high when a B register to C register transfer signal comes high (i.e. signal CDBTC10=1).

#### 5. CDBTA10=CDARF00 · CDFTA00 · CQTXIIO - CFARL20.

This is a B register to A register transfer signal which comes high when the transfer in sequence flip-flop is set (i.e. signal CQTXII0=1), the A register is empty (i.e. signal CDARF00=1) and there is no transfer being made from the F register or ALU (i.e. signals CDFTA00 and CFARL20=1).

#### 6. CDBTC10=CQTXI00 · CFCRL20 CDCRF00+CDCTD10 CQTXI00.

This is the B register to C register transfer signal which comes high when the transfer in sequence flip-flop is reset (i.e. signal CQTXI00=1) and the B register is empty (i.e. signal CDBRF00=1).

The signal is high when the contents of the C register are transferred to the D register on write operations (i.e. signals CDCTD10 and CQTX100=1).

#### 7. CDCTB10=CDABE10 -CDFTB00 - CQTXII0.

This is a C register to B register transfer signal which is high when the transfer in sequence flip-flop is set (i.e. signal CQTXII0=1), the A or B or both registers are empty (i.e. signal CDABEI0=1) and there is no transfer being made from the F to the B register (i.e. signal CDFTB00=1).

#### 8. CDCTD10=(CDDRF00+CDFRF10) · CYWFB10.

This is a C register to D register transfer signal which is high only during write operations.

#### 9. CDDTCI0=(CDARF00+CDBF00+ CDCRF00) CQRD010.

This is a D register to C register transfer 100 signal which is high during a read operation (i.e. signal CQRD010=1) when the A, P C registers are empty.

#### 10. CDDTE10=CQTX010 · CDPTE00 CDIDEIO.

This is a D register to E register transfer signal which is high when the transfer out sequence flip-flop is set (i.e. signal CQTX010=1), the E or F or both registers are empty (i.e. signal CDIDE10=1) and there is no transfer being made from the PSI to the E register (i.e. signal CDPTE00=1).

#### 11. CDETDIO=CQTX000 CDDRF00 CFDRL20+CDDTC10.

This is an E register to D register transfer signal which is high when the transfer out sequence flip-flop is reset (i.e. signal

80

85

STK V. EMC STK 03062

IUD

CQTX000=1) and the F register is empty (i.e. signal CDDRF00=1). The signal is high when the contents of the D register are transferred to the C register during read operations (i.e. signal CDDTC10=1).

## 12. CDETF10=CQTX010 CDEFA10 CDPTF00.

This is an E register to F register transfer signal which is high when the transfer out sequence flip-flop is set (i.e. signal CQTX010=1), the F register is empty (i.e. signal CDEFA10=1) and there is no transfer being made from the PSI to the F register (i.e. signal CDPTF00=1).

#### 13. CDFTE10=(CQTX000 · CDERF00+ CDETD10) · CDFTA00 · CDFTB00.

This is an F register to E register transfer signal which comes high when the transfer out sequence flip-flop is reset (i.e. signal COTX000=1), the E register is empty (i.e. signal CDERF00=1) and there are no transfers being made from the F register to the A or B registers (i.e. signals CDFTA00 and CDFTB00=1). The signal is high during the transfer of the contents of the E register to D register (i.e. signal CDETD10=1).

# CDRTFI0=CDDAKI0 · CQTX000 · CDFRF00.

This is a read data to F register transfer signal which is high when a data acknowledge signal from the device adapter is high, the transfer out sequence flip-flop is reset (i.e. signal CQTX000=1) and the F register is empty (i.e. signal 35 CDFRF00=1).

#### High Speed Sequence Controls Section 308

This section includes the timing circuits of blocks 308-2 and 308-4 together with 40 associated circuits. As mentioned, the clock 308-2, conventional in design, generates the clocking pulse signal for the processor. The generator 308-4, conventional in design, generates write pulse signals of the correct polarity and phase from the PDA signals. These CLK pulses are applied to the register circuits and counter circuits of sections 314 and 318 and condition them for write and loading opera-50 tions respectively. The various sequence and cycle circuits are shown in greater detail in Figures 3c and 3d. The sequence flip-flops of this section shown in Figure 3c are settable by firmware at the start of an 55 operation and reset by hardware at the completion of the operation. The control signals derived from the microinstructions have either a "CE" or "CF" prefix.

As seen from Figure 3C, the hardware se-

As seen from Figure 3C, the hardware sequence circuits include a gate and inverter circuit 308—10, flip-flops 308—1 to 308—9,

and associated gating circuits 308-11 to 308-92 arranged as shown. The flipflop 308—1 is a first pass/format flip-flop which is set to a binary ONE during search operations/write operations. The flip-flop 308-2 is a search flip-flop which is set to a binary ONE during search operations. The flip-flop 308-3 is a read/write storage allow flip-flop which is set to a binary ONE and enables hardware control over reading, writing and incrementing of the read write storage of section 306. The flip-flop 308is a search header operation flip-flop which when set to a binary ONE enables the ALU section to compare all ONE bytes in a search argument of a key field of a record during search key operations.

The flip-flop 308—5 is the transfer out sequence flop which as mentioned controls the direction of byte transfers through registers D. E and F. When set to a binary ONE, it enables transfer of bytes from the D to E and E to F registers. When reset, it enables the transfer of bytes from the F to E and E to D registers. The gate and inverter circuit 308—10 generates the transfer in signal. As mentioned, this signal controls the transfer of bytes through registers A, B and C. When set to a binary ONE, it enables bytes to be transferred from the A to B and B to C registers.

The flip-flop 308—6 is a count gap flop which controls the gap counters of section 318. The flip-flop 308—8 is read operation flop which is set to a binary ONE during read operations. The flip-flop 308—9 is a write operation flop which is set to a binary ONE during write operations.

Certain ones of the signals generated by the above circuits are applied to the circuits of the counter controls which Figure 3d discloses in greater detail. It is seen that the counter controls include flip-flops 308—100 through 308—102 and associated input circuits 308—110 through 308—132 arranged as shown.

The flip-flop 308—100 is a compare cycle flip-flop which is set to a binary ONE by firmware (i.e. signal CFSHOIS=1) during a search operation. It is reset to a binary ZERO when a punctuation bit signal is sensed (i.e. signal CWNR810=1) and the first pass flip-flop is not set (i.e. not first pass). It is also reset when a terminate out bit is sensed in the C register (i.e. signal CDCRT10=1).

The flip-flops 308—101 and 308—102 are connected to form a two stage trap counter. During a write operation (i.e. signals CYWFB10, A1DAV31 and CYFCW10=1), the counter inhibits decrementing of the data counter of section 318 and "traps" sync bytes or address and sync bytes. During a read operation, the counter inhibits

65

70

75

80

85

90

95

100

105

110

115

0

STK V. EMC

the transfer of sync or leading bytes of a field of a record being read from or being sent to the PSI (i.e. signals CQRS010, CDFTX10 and CYIDT00=1) but allows them to be written into the read-write storage section 306 as required (e.g. flag byte read during a read count operation).

#### Read Only Storage Controls Section 304

Figure 3e shows section 304 in block diagram form. It is seen that the section includes a read only memory 304—2, addressable via an address register ROSAR 304—4 which applies a 12 bit address via a path 304—5. The same address is applied to an incremented register 304—6. The register 304—6, conventional in design, increments the address by 1 and loads it into register 304—4 via path 304—7 in response to increment control signal CRINC10 being forced to a binary ONE by control circuits of block 304—8.

Additionally, the contents of register 304—6 are applied to a pair of return registers 304—10 and 304—12 via paths 304—14 and 304—16 respectively. The contents of the register 304—6 are selectively loaded in response to one of a pair of signals CFIR110 and CFIR210 being forced to a binary ONE by the branch trap circuits of block 304—20. Similarly, the contents of return registers 304—10 and 304—12 are selectively loaded into address register 304—4 via paths 304—21 and 304—22 in response to one of a pair of signals CFR1S10 and CFR2S10 being forced to a binary ONE by branch trap circuits 304—20.

When addressed, the store 304—2 applies signals to the sense latching amplifier circuits of a register 304—25 which are in turn applied to the branch trap circuits 304—20 for decoding and to address register 304—4 via paths 304—26 and 304—27 respectively. When the branch trap circuits 304—20 decode a branch microinstruction and the test condition is satisfied, they force a signal CFDTS10 to a binary ONE, and the contents of an address field are loaded into register 304—4.

Additionally, a portion of the contents from circuits 304—25 are applied to the multiplexer selector circuits of a fast branch MUX block 304—28 which also receives a plurality of test condition input signals on inputs 1 to 31, one of which is applied from logic circuits of block 304—30 and other input signals from the ALU section (i.e. bus signals CARBO—CARB7). The circuits of MUX block 304—28 generate output signals representative of conditions being tested which are applied to the branch trap block 304—20. This

block will be described in greater detail in connection with Figure 3f.

12

85

The contents of circuits 304-25 are selectively applied to the flip-flop stages of . local register 304—32 via a path 304—31 and loaded into the register when circuits included in a branch test block 304-34 force a strobe signal CRSTR10 to a binary ONE. Portions of contents of register 304-32 are applied to the branch test block 304—34 and to a multiplexer selector circuit included in a branch MUX block 304-36. Additionally, the MUX block receives signals from the ALU as indicated. Also, register 304-32 loads an address into the address register 304-4 via a path 304-37 when the branch test block forces a signal CFNTS10 to a binary ONE. Circuits included within a sequence decoder 304—38 generate the microoperation control signals in response to the signals applied via a path 304-39 from register 304-32.

Microinstruction Formats

Before describing the various blocks of Figure 3e in greater detail, the different types of microinstructions and their formats will be described with reference to Figures

4a to 4g. Referring to Figure 4a, there is shown a read/write store (RWS) microinstruction word which is used to control the address and data path of information to be read from or written into the read/write storage section 306. As seen from the Figure, this microinstruction word has an op code of 101 specified by bits 0 to 2. Bits 13 and 14 100 form a field which indicates the location in the read/write buffer storage for reading out or writing into a single byte. In the case for more than a single byte read/write operation, the contents of this location 105 specify a starting address. The next field is a count field which includes bits 15 to 18. This field is used primarily for read/write or search count or header address operations which require the reading or writing of 110 information continuously from or to the read/write buffer storage section. For example, the four bit count specified by this field can be loaded into the low order byte position of the data counter contained 115 within section 318 while the rest of the stages of the counter are filled with zeros by the hardware. Bits 19 and 20 serve as an address select field which can specify three ways by which the firmware can generate a 120 read/write storage address. These ways are set out in the associated table. It is seen from this table that when this field is set to "01", the hardware utilizes the contents of the read/write storage address register 125 without referencing the RWS address field of the microinstruction. When the field is

STK V. EMC STK 03064

80

90

25

set to "10", the firmware generates the read/write store address by loading a four bit current logical channel number (LCN) into bit positions 2 to 5 of a read/write store address register; the remainder of the address bits are taken from the RWS address field contained in the microinstruction. When this field is set to "11", the entire RWS address designated by the RWS address field of the microinstruction contained in the read only store local register is used.

Bits 21 and 22 serve as a trap count field and are used to specify the number of bytes which are to be masked in order to perform in various modes of operation. Bits 23 to 26 constitute a four bit field which is used to designate particular sequences required for read/write or search operations involving the storing of the information into the scratch pad store of the read/write storage section. The table indicates the type of operations which are specified by different

codings of the B sub op code bits.

Figure 4b shows the format of an unconditional branch microinstruction. This microinstruction is one of two "fast branch" microinstructions which require that the bits of the microinstruction be decoded from the sense amplifier latches in order to enable generation of a next microinstruction word address within one clock pulse time period. As implied from the name, this microinstruction is used to specify a non test branch operation for the purpose of calling in another micro program or routine. The op code bits 0 to 2 as shown in Figure 4b are coded as 110. Bit 3 is set to a binary ZERO to specify that this is an unconditional fast branch operation. Bits 4 and 5 correspond to a "pre-branch condition" field which is used to specify the setting of a return address before the unconditional branch. More specifically, the read only storage control section 304, as mentioned, includes two branch return registers (i.e. return address register 1 and return address register 2) which are used to keep track of addresses when branching from one routine to another. As indicated by the table in Figure 4b, when bits 4 and 5 are set to "00", branching occurs without requiring any return register to be set to a particular address. When the bits 4 and 5 are set to "10", the branching hardware is operative to increment by one the current address found in ROSAR (304-4) and store it into return address register I before branching to a new address. After the routine branch to has been completed, the contents of return address register I are used to return to the first or original routine. When bits 4 and 5 are set to "01" the return address register 2 is loaded with the address of the microinstruction after it

has been incremented by 1. This address register provides a second level of branch return. As indicated by the same table, it is undesirable to set bits 4 and 5 to "11' because this will result in loading the same address into both address registers 1 and 2.

As indicated by the Figure 4b, bits 6 to 18 constitute a 12 bit branch address wherein bit 18 is the least significant bit and bit 6 constitutes an odd parity bit. Bits 19 and 20 constitute a "branch to address condition" field which specifies the conditions indicated in the table. When these bits are set to "00", the store will branch to a location defined by the branch address of the microinstruction. When bits 19 and 20 are set to "01", the store branches to an address contained in return address register 2 while it will branch to the address contained in return address register 1 when these bits are set to "10". Bits 19 and 20 will not be set to "11" since this is an illegal condition. Bits 21 to 26 normally contain all zero since they constitute an unused field.

The rest of the bits are as indicated. Figure 4c shows the format of the second fast branch microinstruction which corresponds to a fast conditional branch (FCB) microinstruction. As shown, it has the same op code as the unconditional branch microinstruction but has bit 3 set to a binary ONE. Bit 4 serves as a set return address register I field. When this bit is set to a binary ONE and the test result is positive, the contents of the read only store address register are incremented by 1 and stored in the return address register 1. The store then branches to the location specified by the branch address field of the fast conditional branch microinstruction. Bit 5 is a reset test flop field bit which when set causes certain test flops to be reset after completion of the test. One of these flipflops corresponds to an end of command

flip-flop described herein.

basis.

Bits 6 to 18 constitute a branch address field and bits 19 to 23 constitute a multiplex test condition field. The test conditions are defined as indicated in table 1 of Figure 4c. There can be up to 31 flip-flops which are capable of being tested. The table indicates some of the more pertinent flip-flops. The test is made to determine whether or not a flip-flop is in its binary ONE or set state. When this field is set to all ones, this indicates that none of the 31 test flops are to be tested but that one of the latches which receive the ALU result bus signals defined by bits 24 to 26 are to be tested. Bits 24-26 constitute a test condition latch field which is coded as indicated by Table 2. This field enables the contents of any one of the 8 bit registers delivered through the ALU section to be tested on a bit by bit

110

Figure 4d illustrates the format of a normal conditional branch (NCB). microinstruction. Unlike the fast conditional branch and unconditional 5 branch microinstructions, this microinstruction is decoded at the output of the read only store local register and requires an interval of two clock pulse periods to obtain the results of the test. The conditional 10 normal branch microinstruction enables the testing of any bit position (binary ONE and binary ZERO states) of a register specified by the A operand field of the micro-instruction. As seen from Figure 4d, this microinstruction has an op code of "111". Bit 3 indicates whether the binary ONE or binary ZERO of outputs of the registers specified by the A operand field are to be tested. Bits 4, 5 20 and 19 are unused fields and therefore set to binary ZEROS. Bits 6 to 18 constitute a branch address field while bits 20 to 22 constitute a latch field. As seen from the Figure, these bits when coded as indicated 25 by Table I define the bit position of the ALU selected register to be tested. Bits 23 to 26 constitute the A operand (AOP) field which defines as indicated by Table 2 any one of 16 registers whose contents can be stored in the ALU latches.

Figure 4e shows the formats of an input/output, (I/O) microinstruction. This microinstruction is used to condition the mass storage processor, PSI, and device adapter circuits to handle those operations requiring information transfers to/from the device adapter and IOC interfaces. As seen from Figure 4e, this microinstruction word has an op code "011". Bit 3 corresponds to 40 a set counter bit which when set to a binary ONE causes either an input/output counter or data counter to be loaded with either the contents of the count field which comprises bits 11 to 18 or from the RWSLR. This 45 operation occurs for input/output operations such as a service code sequence, a write data sequence, a read data sequence, a search key or data sequence etc. When this bit is set to a binary ZERO, none of the aforementioned counters are loaded with information but only the sequence flip-flops are set as indicated by Tables 1 to 6 of Figure 4e. Bit 4 is used when a count field is used (i.e. Bit 3 is a 55 binary ONE). This bit is used to indicate to the processor which byte of the two byte PSI or data counters to be loaded with the count specified by the count field. In the instance where two bytes are loaded into 60 the counters, this requires two I/O microinstruction words. Every time the low order byte positions of a counter are loaded, the upper order byte positions of the same counter are all reset to binary 65 ZEROS. When bit 4 is a binary ZERO, it

indicates that the low order byte positions of the counter are loaded with the count field of the I/O microinstruction. Conversely, when bit 4 is a binary ONE, the upper byte positions of the counter are loaded with the microinstruction count field. When bit 3 of this microinstruction is set to a binary ZERO, this signals to the processor which flip-flops in fields 1 to 3 and those in the error correction and foreign mode fields are to be set or reset. When bit 4 is set to a binary ONE, those flip-flops designated by these fields are set to binary ONES. When bit 4 is a binary ZERO, those flip-flops designated by the fields are reset to their binary ZERO states. Bit 4 has no significance when the fields are coded to contain all zeros. Tables 4 to 6 set forth representative codes for certain ones of the flip-flops contained within the mass

storage processor.

Bits 3 and 6 specify a sub op code field when the count field is used (i.e. bit 3 is a binary ONE). The op code field defines which one of the counters (i.e. PSI byte counter or data counter) is to be loaded and the source of the count to be loaded (i.e. from the read/write storage local registers or read only store local register). Table 1 defines the various codings for these bits and corresponding functions. Bits 7 to 10 define a PSI sequence flop field when bit 3 is set to a binary ONE. These flip-flops as mentioned above, set up the data paths for the PSI apparatus to handle data transfers 100 between the IOC and mass storage processor. Table 2 illustrates the codes for designating different ones of these four flipflops. While the coding of bits 7 to 10 illustrates the setting of a single flop, they 105 can be modifed to set more than a single sequence flop with a single microinstruction. Bits 11 to 18 designate a count field which is used by the processor to load either the PSI counter or data 110 counter. When loading the two byte wide counters, either the PSI or sequence flops are set only when a count is being loaded into the upper byte stages of the counter. As indicated by Figure 4E, bits 19 and 20 115 are unused bits when bit 3 is a binary ONE. Bits 21 and 22 serve as a trap count field when bit 3 is a binary ONE. This count field indicates the number of bytes to be trapped by the processor during a read, a write or a 120 search operation. Depending upon the particular record format being processed, this field will be set to specify the correct number of bytes to be trapped. Bits 23 to 26 define a sequence flip-flop field when bit 3 125 is a binary ONE. The sequence flip-flops are set to predetermined states which in turn establish the path for accomplishing bidirectional transfers of information through the various registers of the MSP. 130

75

STK V. EMC STK 03066

The codings for these fields are as indicated in Table 3 of Figure 4e and some of these flip-flops were previously discussed above.

When bit 3 is set to a binary ZERO, bits 5 to 26 are utilized as indicated by Tables

4 to 6.

Figure 4f illustrates two formats for microinstructions used for specifying different arithmetic operations. 10 arithmetic operation microinstructions include an op code "010". Bit 3 is used to indicate different formats of the microinstruction. Bits 4 to 7 constitute a sub op code field which defines up to 16 different arithmetic operations some of which are logical operations. Table 1 indicates certain ones of the arithmetic operations coded by bits 4 to 7. These operations are well known and therefore will not be described in greater detail herein. Bits 8 and 9 serve as a carry in field and are coded in accordance with Table 2 to specify three different carry in conditions for performing various arithmetic operations. Bits 15 to 18 are not used when bit 3 is a binary ZERO and therefore these bits are binary ZEROS. Bits 10 to 14 are coded as indicated by Table 3 to specify the destination of the result produced by an arithmetic operation. Bits 19 to 22 constitute a B operand (BOP) constant field which indicate the source of the B operand in accordance with Table 4. Similarly, bits 23 to 26 indicate the source of the A operand in accordance with Table 5. It will be noted from Figure 4f that when bit 3 is a binary ONE, bits 15 to 22 are used as the B operand.

Figure 4g illustrates two formats for microinstructions used for specifying different types of logical operations. The logical operation microinstructions include an op code "001". The state of a format bit 3 when a binary ZERO indicates

that one of the registers designated in the table is to be the source of the B operand. When bit 3 is a binary ONE, the 8 bit constant field of the microinstruction is the B operand. Bits 4 to 7 of a sub op code field 50 designate the logical operation to be

performed by the ALU upon the A and B operands. Table 1 indicates some of the

type operations.

Bits 15 to 18 are not used when bit 3 is a ZERO. Bits 10 to 14 constitute a destination of ALU result field and are coded to specify one of the registers in the table indicated for receiving the result generated by the ALU. All codes, except 11110 and 11111, cause the result to be delivered to the designated register as well as storing it in the ALU latches. With codes 11110 and 11111, the result is not transferred to a register but is only stored in the ALU latches.

As mentioned above, bits 19 to 22 define the source of the B operand to the ALU when bit 3 is a ZERO. Bits 15 to 22 define the B operand when bit 3 is a binary ONE. Also, bits 8 and 9 are not used in this type microinstruction. Similarly, bits 23 to 26 define the source of the A operand to the ALU.

#### Detailed Description of the ROS Circuits of Figure 3e

75

With reference to Figure 3f, certain ones of the circuits of Figure 3e will now be described in greater detail. Referring to this Figure, it is seen that the branch trap block 304-20 includes the circuits 304-200 to 304-215 which are arranged as shown. As mentioned, these circuits generate the required signals during the execution of the two fast instructions which are directly applied to the circuits by sense amplifier latches 304—25. The signals produced by the branch trap circuits are generated in accordance with the following Boolean equations:

1. CFDTS10 (ROS DATA TO ROSAR)= CFUCBIO - CBNOK00 - CFRIS00 -CFR2S00+ CFFCB10 - CBBOK10.

2. CFFCB10 (Fast Conditional Branch)= CFBNHIO CDR0310.

CFIR110 (incrementer to return Reg 1)= CFUCB10 CBNOK00.

4. CFIR210 (incrementer to return Reg 2)=CBNOK00 - CFUCB10 - CRD2210.

5.. CFRISIO (return Reg 1 to ROSAR)= CFUCBIO CRD1910 CBNOK00.

6. CFR2S10 (return Reg 2 to ROSAR)= CFUCB10 · CRD2010 · CBNOK00.

7. CBBOK10 (branch OK for FCB)= CBBOKOC CBTRB00+CBTRB10 CBRBT00+CBNOKIO.

8. CBBOKOC (FCB Test conditions)= CBBOKOA · CRD1900 · CBBOKOB.

The signals CBBOKOA, CBBOKOB and CBRST00 are derived from corresponding ones of the multiplexer selector circuits 110 304-280 to 304-285 included within the fast branch MUX block 304-28. These circuits receive a number of input signals from various parts of the processor and these signals representative of certain test 115 conditions are sampled and the results of the sampling are applied to the branch trap circuits 304-20 as shown. One of the inputs applied to multiplexer circuit 304-284 is signal CBEOC10 which is 170 generated by a flip-flop 304-300 included within the fast branch logic circuits of block 304-30. As shown, this block includes this flip-flop together with associated gating circuits 304-301 to 304-303 arranged as 125 shown.

105

100

STK V. EMC STK 03067

Other test signals include an index pulse not received signal A1IDT00 generated by the adapter section 310 in response to index pulse signal from line IDX, a gap counter not equal zero signal CCGCZ00 from section 318, a data counter not equal zero signal CCDCZ00 from section 318, a data termination flip-flop not set signal PKDDT00 from section 302, and first pass/format flip-flop set signal CQFPF10 from the high speed sequence controls section 308. It will also be noted that circuit 304-208 receives an A equal B signal CAAEB10 and an A greater than B signal CAAGB10 from the ALU section 316.

It is also seen from Figure 3f that the branch test circuits of block 304-34 include the circuits 304-340 to 304-344 which are arranged as shown. These 20 circuits are operative to generate branch signals in response to a normal condition branch microinstruction stored in read only store local register 304-32. Additionally, these circuits generate signals for enabling 25 sequence decoder circuit 304—38 which is operative to decode bits 23 to 26 of the normal condition branch microinstruction which are applied via path 304—39. The multiplexer selector circuits included within branch MUX block 304—36 provide a branch signal CBNOK10 in response to sampling one of the latches of the ALU section as specified by latch field bits 20 to 22. Additionally signal CBNOK10 is 35 applied to the circuits included within increment logic circuit block 304-8. As shown, this block includes circuits 304-80 to 304-83. These circuits force signal CRINC10 to a binary ONE in accordance 40 with the following Boolean equation:

#### CRINCIO (increment ROSAR)= (CBNOK00 - CFUCB00 - CRRES00) -(CFFCB00+CBBOK00).

#### Read/Write Storage Section 306

Figures 3g and 3h show in greater detail the read/write storage section 306. As seen from the Figure, it includes a scratch pad memory 306-2 constructed from a number of 256×1 bit arrays, conventional in design, arranged as indicated. The memory 306-2 is addressed via an address register 306-4 which includes a number of amplifier latches. The register 306-4 can be loaded 55 from the ROSLR via a bus 306-6 in response to a control signal CFSRL10 generated by an AND gate and amplifier circuit 306-8. Similarly, predetermined bit positions of the register 306-4 can be 60 loaded with ALU bits from a RWS device port register 306-7 over a path 306-5 in response to a control signal CFDVP10. As seen from Figure 3g, register 306-7 is loaded from the ALU bus latches of Section 316. When signal CFSRL10 is a binary ZERO, register 306-4 can be loaded with an address supplied by register storage 306—12. This register receives an address from circuits of a block 306—14 after the address from register 306-4 applied via a path 306-25 has been incremented by 1 and applied thereto when an increment signal CWINC10 and an increment only signal CWIN010 are both forced to binary ONES. The circuits 306—16 to 306—19 force signal CWINC10 to a binary ONE during all write operations, during search operations and read operations, in accordance with the equation:

### CWINC10=CWWPA10 CWDTM00+ CQSH010 CQFPF00 CWPTM10+ CFRED10.

The circuit 306-20 forces signal CWINO10 to a binary ONE during search operations when signal CWTOG10 is a binary ZERO and CWINC10 is a binary ONE.

The high order three address signals from address register 306-4 are applied to chip enable decoder circuits 306-30 which generates enabling signals for each row of arrays. When the circuits of block 306—32 force read signal CWRED10 to a binary ONE, the byte contents of an addressed location are loaded into an output local register 306-40. The circuits 306-33 to 306-39 of block 306-32 force signal CWRED10 to a binary ONE when the sequence decoder of section 304 generates signal CEMSQ08 and when flip-flop 100 306-36 forces signal CWREDIA to a binary ONE.

The block 306-42 shows representative stage of the DATA In circuits used in entering a bit of information 105 into an addressed location. The circuits include AND gates 306—43 to 306—47 and amplifier circuits 306—48 arranged as shown. Gates 306—44 to 306—46 are used to store information from the C, D and F 110 registers of the Buffer Section. Gate 306-47 is used to store information from local register 306-40. The various transfer signals are generated by the circuits of block 306-70 which will be described in 115 connection with Figure 3H. Also shown, the local register 306-40 can be loaded from the ALU section via a path 306-50 when the read only store forces a signal CFNRL10 to a binary ONE.

During a write portion of a memory cycle, a gate and inverter circuit 306-52 is enabled to apply a write pulse generated by write pulse generator 306-54 which drives a set of eight driver inverter circuits 125 CWNPL00—CWNPL07 causing the

65

75

80

85

information to be written into an addressed location. The circuit 306—52 is enabled when another gate and inverter circuit 306-56 forces a write pulse allow signal to

a binary ONE.

Figure 3h shows the circuits 306-71 to 306—88 of block 306—70 for generating the various transfer control signals, CWDTM10, CWCTM10, CWFTM10 and CWNTM10. The AND gates 306-76 to 306-78 decode the states of certain ones of the sequence flip-flops and condition the inverter circuit 306-79 to force signal CWDTMOB to a binary ZERO for transferring bytes from the D register to the read-write store during other than a first pass search operation. This in turn causes the AND gate and inverter circuit 306-80 to force signal CWDTM10 to a binary ONE. Similarly, the read only store by forcing signal CEMSQOA to a binary ZERO causes a transfer of bytes from the D register in response to the decoding of a "OA" contained in the sub op code field of a RWS microinstruction.

The circuits 306—81 to 306—86 decode the states of certain ones of the sequence flip-flops to force signal CWCTMOB to a binary ZERO when transferring bytes from the C register to the read-write store during a first pass search operation. Similarly, the read only store forces signal CEMSQ09 to a binary ZERO upon decoding of a "09" in the sub op code field of a RWS microinstruction. This allows the transfer of bytes from the C register to the read write

store.

The AND gate and inverter circuit 306—88 enables the writing of the contents of the read-write store local register back into the read write store upon the decoding of either a "OB" or "OC" in the sub op code field of a RWS microinstruction. The AND gates 306-71 through 306-74 respectively force transfer signal CWFTM10 to a binary ONE during write count or key operations, bytes trapped by the trap counter during search operations. during read count or key operations when a

byte is transferred from the register F. In addition, Figure 3h shows the logic circuits of block 306-100 used to generate toggle signal CWTOG10, a toggle only signal CWTGO10 and a toggle and increment signal CWTIC10. These circuits by generating signal CWTOG10 provide the facility to increment the contents of the RWS address register through 512 memory storage locations within one clock (PDA) time. This arrangement facilitates the storage of information from two sources during search operations. That is, it enables the immediate storage of count and key field bytes from a selected device into a first 65 group of storage locations (0-511) and the

storage or search argument bytes from the IOC into a second group of locations (512-1023). The second most significant bit position (CWS01) is "toggled" between two states to logically increment/decrement the memory address by 512 locations since

it has a positional value of 512.

The toggle logic circuits of block 306—100 include AND gates 306—101 to 306-104, amplifier circuit 306-105 and inverter circuit 306-106. The toggle signal CWTOG10 is generated in response to decoding the states of certain sequence flipflops. In particular, AND gates 306—101 to 306-104 respectively force signal CWTOG10 to the proper state for storing a flag byte contained in the F register during a search operation not first pass, for storing a byte contained in the D register during any search operation in the compare cycle when the punctuation bit has not been sensed on a previous read cycle, for storing a byte contained in the C register first pass in the compare cycle and for read out of a search argument byte from the read/write store during a search not first pass

The AND gate and amplifier circuits 306-110 and 306-111 of block 306-100 combine the toggle signal CWTOG10 with increment signals CWINCIO and CWINCOO as shown, to produce toggle only signal CWTG010 and toggle and increment signal CWTIC10. With the increment signal CWINCIO set to a binary ONE, the toggle only signal CWTG010 is held at a binary ZERO preventing the access of the next group of 512 storage locations. The AND gate 306-20 of Figure 3g forces increment only signal CWIN010 to a binary ZERO when signal CWTOGIO is a binary ONE enabling the address from the increment latches to be loaded into the address register flip-flops. When CWSO110 of the address register is to be toggled to a binary ZERO and the address incremented by one. AND gate 306-110 switches signal CWT1C10 to a binary ONE.

#### General Register Section 314 and Arithmetic Logic Unit Section 316

Figure 3i shows in greater detail sections 314 and 316. As seen from the Figure, the ALU includes a main ALU 316-2 and an auxiliary ALU 316-4 together with their associated mode select, carry-in and carry enable circuits (e.g. circuits of block 316—6) in addition to parity error check circuits 316-8. Since the auxiliary ALU 316-4 only serves to duplicate the operation to the main ALU 316-2 for checking purposes, its associated circuits need not be shown and its operation need not be described.

75

90

The main ALU 316-2 is capable of performing 16 logical operations or 32 arithmetic operations in response to applying predetermined combinations of input signals to its carry-in (CIN), carryenable (CEN) and mode control (M0-M3) input terminals. The ALU is enabled for receiving A and B operand signals by circuits 316—62 to 316—65 which force enable signal CACEN00 to a binary ZERO. When not performing either logic or arithmetic operations, the ALU 316-2 operates in a subtract mode (i.e. normally used during search and error detection operations). That is, the natural state of the ALU in the absence of applying signals to the mode control circuits is

#### f=A-B-1

where f=the result. More specifically, the mode signals applied to the ALU are coded "0110" which condition the ALU to produce the desired result (see Figure 4f). The ALU subtracts the A and B operands by performing a ones complement addition and produces a result corresponding to A-B-1 at stages CAF00 to CAF07. The absence of a carry in signal causes a forced carry-in to be applied to carry-in input terminal Cin. The result is in turn applied to the result bus latches 316—10 and result latches 316-12 when sampled in response to a strobe signal CASTR10 generated by the circuits of a strobe/RST control block 316-20. The A=B output terminal of both ALUs are compared by an AND circuit of block 316—8 to verify the comparison.

During a logical operation, the sub op code field of the microinstruction (i.e. CRN0410-CRN0710) is applied to the decoder 316-60 from the ROS local register of section 304. The input signals CRN0410 to CRN0710 together with strobe signals CASTR10 and CASTR00 from control 316-20 condition the decoder 45 316-60 to generate the appropriate mode control input signals which are in turn applied to inputs M0 to M3. As mentioned above, these signals in turn condition the main ALU to perform the logical operation 50 designated. The A operand (AOP) is applied from the general purpose register location or "hot" register having the address specified in the A op field of the microinstruction word (i.e. bits N23 to N26). The B operand (BOP) is applied from: (1) a general purpose or hot register specified by the B op field of the microinstruction word (i.e bits N19 to N22) or (2) from an 8 bit constant specified by the microprogrammer (i.e. bits 15-22 of the microinstruction word stored in the ROS local register) when the microinstruction op code format indicating

bit is a binary ONE. As seen from Figure 3h, these signals are applied via the B operand multiplexer selector circuit included within block 314—2. At this time, bits N0 to N2 of the op code field together with bits 19 to 22 condition a decoder within the block 314-2 to apply the appropriate selection signals to the B operand MUX circuit 314—22.

After performing these specified logical operations, the main ALU 316-2 delivers the result to the result bus circuit 316-10 and to the circuits of a result test and storage block 316-30. As seen from Figure 3i, the circuits 316-30 include a plurality of flip-flops 316—300, 316—310 and 316—330 together with gating circuits 316—301 to 316—304, circuits 316—311 to 316-325 and circuits 316-331 to 316-333 arranged as shown. The equal store flip-flop 316-300 is set to its binary ONE state when the ALU forces equal signal CAEQA 10 to a binary ONE at the same time strobe signal CASTR10 goes to a binary ONE. The flipflop 316-300 is reset to a binary ZERO when signal CAEQA10 is forced to a binary ZERO during a compare time interval (i.e. when signal CACMT10 is a binary ONE). The A greater than B stored flip-flop 316-310 is switched to its binary ONE state when the equal signal CAEQA10 is a binary ZERO and a carry-out signal CAAC010 is a binary ONE. The flip-flop 316-310 is reset to a binary ZERO when strobe signal CASTR10 is forced to a binary ONE. It will be noted that the output signals from flip-flops 316-300 and 316-310 are recirculated back to circuits 316-305 and 316-314 respectively. Thus, when either flip-flop is reset to a binary ZERO, it causes the appropriate one of the signals CAAEB10 and CAAGB10 also to be forced to a binary ZERO. As mentioned above, it is the signals CAAEB10 and CAAGBIO which are applied to the branching circuits. These signals indicate whether the comparison was successful during a search operation. The carry out store flip-flop 316-330 is set to its binary ONE state when there is carry out generated by the main ALU 316-2

The result contained in the result bus 115 circuits 316-10 is transmitted to the read only storage control section 304 and to the general register section 314. As mentioned, the result either remains in the result bus circuits for subsequent branch testing or is 120 delivered to one of the 31 registers specified by bits N10 to N14 of a logic or arithmetic type microinstruction (i.e. the DOR microinstruction field-see Figures 4f and 4g). The strobe allow signals produced by 125 control block 316-20 allow resetting of the result circuits 316-12 and error checking circuits 316—8 via a reset signal CARSTOO.

70

As seen from Figure 3i, these circuits include a plurality of gating circuits 316-21 to 316-28 arranged as shown. The AND gate and inverter circuit 316-21 is operative to generate strobe allow signal CASTA10 which allows storing of the ALU result for all arithmetic, logic and normal conditional branch type microinstructions with the exception of a logic type microinstruction which has bits 4 to 7 set to all binary ONES. This allows delivering the result of a previous microinstruction without destroying stored information. In the case of a logical operation signal CFLOGIO equals a binary ONE, in the case of an arithmetic operation signal CFAR010 equals a binary ONE and in the case of a normal conditional branch operation, signal CFNCB10 is a binary ONE. These signals in turn condition amplifier circuit 316-25 and inverter circuit 316-26 to generate the appropriate strobe signals. The AND gate and amplifier circuit 316-28 is operative to force reset signal CARPFOO to the correct state in response to reset signal CARES00 and strobe signal CASTR00 as shown.

As with a logical operation, bits CRN04 to CRN07 together with the strobe signals condition the decoder 316-60 to generate the appropriate mode control input signals during an arithmetic operation. Additionally, a carry in signal CACIN00 is generated from the carry in bits CRN08 and CRN09 of the microinstruction word by circuits not shown and the results applied to the carry in (CIN) terminal. Depending upon the coding of the microinstruction word bits mentioned, the signals applied to the CIN and M0 to M3 terminals specify the particular arithmetic operation to be performed. The A and B operands are derived from the sources mentioned above in connection with the description of a logical operation. Similarly, the result loaded into the result latch circuits 316—12 and applied to the result bus can be delivered or stored for testing as determined by the bits of the DOR field of the microinstruction word.

As mentioned, during a search operation. the ALU performs all arithmetic operations required for processing count, key and data field portions of a record during the 55 respective count, key or data field search operations. The ALU is conditioned to perform the desired logical operation (A-B-1) during which the B operand obtained from the B operand multiplexer selector circuit 314-22 from either the C register or the read/write storage section is compared with the A operand obtained from the A operand multiplexer circuit 314-22 via the D register. Initially, a logic 65 type microinstruction coded to specify a

F=1 operation (see Figure 4f) causes the ALU to force equal signal CAEQA10 to a binary ONE. At the same time the strobe signal CASTR10 is forced to a binary ONE which switches equal compare flip-flop 316-300 to a binary ONE. During the search, no further arithmetic or logic microinstructions are executed and therefore, strobe signal CASTR10 remains a binary ZERO. At the completion of the search operation, a FCB microinstruction is used to test the state of signals CAAEB10 and CAAGB10 to determine whether there was a successful comparison. The microinstruction also forces the strobe signal CASTR10 to a binary ONE which resets the ALU circuits.

Considering now the general purpose register and multiplexer circuits of block 314, it is seen from Figure 3i that the general purpose registers are included within two solid state memories 314-3 and 314-4. These memories, conventional in design, are addressable through their respective address registers 314-6 and 314-8. These registers receive signals directly from the read only store local register (i.e. CRN20 to CRN22 and CRN12 to CRN14) which provide the address for the general purpose register. The contents of the address register are then delivered to a selector register whereafter they are applied to the ALU.

The address selection circuits included within block 314—20 decode bits N19 to 100 N22 providing output selection signals BM0 to BM2 as inputs to the B operand multiplexer circuits 314-22. The multiplexer output signals from the selected source register are applied to the selector 105 register 314-28 when the control circuits of block 314-34 force signal CABBA00 to a binary ONE. This is done in response to the specific codings of bits N0 to N3 and N19 which determine whether the 110 information from a general purpose register or one of the other registers of the system is to serve as the B operand source. Flip-flops included within a MUX address store block 314-21 retain an indication of bits N20 to 115 N22 for continuous selection of that source during a search operation. In greater detail, it is bit 19 applied to the control circuits 314—34 which determines which one of the allow functions CABBA10 or CABBA00 is 120 to be forced to a binary ONE to select either the addressed general purpose register or register coupled to multiplexer circuits of block 314—22. In a similar fashion, the multiplexer address selection 125 circuits of block 314-26 apply the control signals AMO to AM2 to the A operand multiplexer circuits of block 314—24 so as to select one of the registers as the source of the A operand. Also, flip-flops included 130

within the MUX address store 314-27 retain an indication of bits N24 to N26 for further reference during a search operation. The control circuits included within block 314-32 in response to bits NO to N2 and N23 are operative to generate allow signals CAABA10 and CAABA00 to select the output of an addressed general purpose register or one of the registers coupled to the multiplexer circuits 314-24. When signal CAABAIO is forced to a binary ONE, the contents of an address general purpose register are applied to selector 314-30. Conversely, when allow signal CAABA00 is forced to a binary ONE, the contents of a designated one of the registers is selected and applied to selector 314—30. As mentioned previously, when writing information into a general purpose register of each of the memories 314-2 and 314-4, the addresses are defined by bits N12 to N14 (i.e. by the DOR field of the logic or arithmetic type microinstruction) and writing takes place in response to a pulse signal CLK generated by write generator 308-4.

#### Data and Gap Counter Section 318

Figure 3j shows in greater detail the logic circuits which comprise section 318. 30 Referring to that Figure, it is seen that the logic circuits for the data counter (DAC) includes a main counter 318-2 and an auxiliary counter 318—4 together with their decrementing control circuits 318—6 and error checking logic circuits 318-8. Additionally, the section includes count logic circuits arranged to signal when the data counter has been decremented to zero. As shown, these circuits included within block 318-10 include a decoder 318-100, conventional in design, which is operative to force signal CDDCZIA to a binary ONE when it detects that the data counter has been decremented to zero. This in turn conditions an AND gate 318-102 of flipflop 318-104 to be switched to its binary ONE state when either one of the AND gates 318-108 or 318-110 cause an amplifier circuit 318-112 to force signal CCSCZ10 to its binary ONE state. The flipflop 318—104 is reset to its binary ZERO state via an AND gate 318—106 when a hold signal CCCZHIO is forced to a binary ZERO. As briefly described previously, the counters 318-2 and 318-4 are loaded in response to an I/O microinstruction word. Specifically, an 8 bit count field is loaded into these counters from the read only storage local register (i.e. bits CRN15 to CRN22) or from the read/write store local register (i.e. from stages CWNR1 to CWNR7). Either of these sets of signals are applied to a counter bus and then loaded

into the counters simultaneously in response to pulse signal CLK and signals CCDUL00 (DAC upper load) and CCDLL00 (DAC lower load) being forced low. The specific count field selected is established by the set count field of the I/O microinstruction word. It is this count field which is operative to cause the generation of signals CFCFR10 and CRCFM10.

During operation, both counters are decremented by a decrement signal CCDEC10 each time a byte is transferred to/from the device adapter. Although decrementing can occur during a write operation, a read/search operation or load operation, only the AND circuit which generates the decrement signal for a read/search operation is shown (i.e. AND gate and amplifier circuit 318—60). The error checking logic circuits 318—8 include a conventional comparator which compares the contents of both counters and if a non-comparison is detected, these circuits force an error signal CCDCE10 to a binary ONE.

As seen from Figure 3j, this section also includes a main gap counter 318-12, an auxiliary gap counter 318—14 together with decrementing control circuits 318-16 and error checking circuits 318-18. Also, as shown, section 318 includes gap decoder circuit 318-20 which generates an output signal indicating when the main gap counter has been decremented to zero. Both counters 318-12 and 318-14 are loaded simultaneously with an 8 bit 100 constant from the ALU result bus in response to the CLK pulse signal when signals CCGLL00 (GAC lower load) and CCGUL00 (GAC upper load) are forced to binary ZEROS. The loading takes place 105 upon the decoding of an arithmetic type microinstruction which causes the generation of signal CFGLL10. This occurs in response to an arithmetic type microinstruction. During operation, both 110 counters are decremented by signal CCGEC10 which is generated by a flip-flop 318-160 which is set via an AND gate 318—162 in response to signal CQCGP10 being forced to a binary ONE. The flip-flop 115 318-60 is reset via an AND gate 318at the end of a clock (PDA) pulse time. The contents of both counters are compared by a conventional comparator circuit included within block 318-18 and when a non- 120 comparison is detected, the comparator circuit forces an error signal CCGCE10 to a binary ONE.

#### Device Level Interface Control Section 310

With reference to Figure 3k, the section 310 will be described in greater detail. As discussed previously, this section comprises

an integrated control adapter 310-2 and read/write multiplexer and buffer circuits included within block 310-3. As seen from Figure 3k, the adapter 310-2 includes a plurality of registers which enable conditioning of the adapter and a selected device. These registers include a device port register 310-1, a device command register 310-4, and an adapter command register 310-6 and a parameter register 310-8. Each register is enabled in a specific sequence to store information. Specifically, the various registers are enabled for storing signals by control signals CFDPL10, CFDCL10, CFACL10 and CFPRL10. These signals are derived from the decoding of a specific field of a logic type microinstruction by the DOR decoder circuits of section 304. As shown, in response to the control signals, the registers are loaded from the ALU result bus of block 310—3. The write multiplexer circuit serves as gating device for all write operations and receives input signals from the various sections of the processor (e.g. from the F register of buffer section 302-50).

The device port register 310—1 is normally the first register loaded in a given sequence and is used to associate a logical channel number with a specific device. That is, the low order four bits applied by the ALU result bus are loaded into the device port register and a device port decoder 310—10 decodes these bits into a number of select signals, only some of which are shown, used to select any one of 12 mass storage devices. The parameter register 310-8 is usually the second register loaded and it is loaded from the read/write storage section with previously stored device parameter byte information required for a particular operation via the ALU. This information byte is decoded by adapter control circuits 310-12 and generate control signals for conditioning the adapter to operate in a given mode. Since details are not relevant to the present invention, they are not given herein.

The device command register receives information from the ALU and forwards the information directly to one of the devices specified to execute the command (i.e. selected by device port decoder 310-10). The adapter command register 310—6 is normally the last register loaded in sequence and conditions the circuits within the adapter 310-2 to execute the device command specified. The lower order four bits AIAC4 to AIAC7 are decoded by an adapter command decoder 310—14 which generate signals used to set various tag lines of the interface or specify certain types of operations within the 65 adapter. Bits 0 to 3 are applied to control gating circuits and used to set various control flip-flops included within a block 310—16. These flip-flops establish whether the adapter is to perform a read or write operation in addition to defining other information relative to that type of operation. Since a discussion of such circuits is not relevant to the present invention, it is not included herein.

As also seen from Figure 3k, the adapter includes a shift register 310-18 and associated read/write clock and counter circuits 310-20. When operated in a serial mode, information applied by an interface line SRI from the device is shifted into the shift register 310—18 under the control of a read clock, conventional in design. As shifting occurs, a bit counter included within block 310—20 is incremented by one every other bit interval since normally synchronization bit brackets each data bit. When the counter has been incremented to a predetermined count, such as a count of six for six bit mode or a count of eight for eight bit mode, it causes the assembled character to be transferred in parallel to a read buffer 310-32. Additionally, this transfer causes the adapter 310-2 to generate a data available signal (AIDAV10 is forced to a binary ONE) which indicates to the processor sequence logic circuits of section 304 that a data byte has been stored in read buffer 310-32 and is ready for transfer into the F register of section 302. Upon sensing the data available signal, the sequence control circuits of section 304 are operative to acknowledge the signal by forcing a data acknowledge signal AIDAK10 to a binary ONE. Thus, it is seen that the generation of signals AIDAV10 and AIDAK10 enable the adapter and processor operations to be synchronized with one another.

In the case of a write operation, the adapter 310-2 upon detecting that data has been stored in the F register is operative to force device strobe signal DXDCS10 to a binary ONE. The command loaded into the device command register 310—4 is decoded and executed. In a similar fashion, the adapter utilizes the signals AIDAKIO and AIDAVIO for sampling when a byte has been stored in the F register and is ready for transfer into a write buffer 310-34 and then into the shift register 310—18 for shifting out a bit at a time onto interface line SWO. Although not shown, the shift register 310-18 includes gating circuits which are arranged to be conditioned by the clock circuits 310-20 to alternate the bit transfers with sync bits. By contrast when the adapter operates in a parallel mode, it transmits and receives information bytes from the write buffer 130

1,496,780

310-34 and read buffer 310-32 respectively via bus lines D10-D17. In this mode, lines SWO and SRI transmit strobe signals.

22

Description of Operation

With reference to the flow charts of Figures 6a to 6c, the operation of the system of Figures 1, 2 and 3a to 3k will now be described. Initially, the IOC 101-6 receives an I/O instruction specifying a search key operation. The IOC 101—6 decodes the instruction and then initiates a transfer of I/O command bytes to the mass storage processor 300. The bytes include a 15 logical channel number (LCN) byte and bytes of one or more channel command words. The LCN byte indicates which channel is to be involved in the execution of the instruction. The command words include a command code byte specifying the type of operation, count bytes specifying the number of bytes to be transferred between main storage and the processor, and address bytes specifying a main storage starting address for the

transfer. After the IOC receives signals indicating that the mass storage processor 300 is ready to receive command bytes to execute the 30 operation, it starts transferring the bytes starting with the LCN byte. Figure 6a illustrates in simplified form a portion of a channel program initiation routine used in processing a next command. In Figure 6a as well as the other flow charts, the different microinstructions are designated by "relative" or logical addresses which include the name of the routine and a letter-number (e.g. AO700). The 40 microinstructions of each routine are assigned sequential physical addresses in the read only store according to the alpha numerical ordering of their relative addresses. The mass storage processor 300 45 prepares for receipt of the command by executing an I/O type microinstruction which generates subcommand signals which cause the setting of the TRM and RQD flip-flops and the loading of the PSI 50 counter with a predetermined count (i.e. count of 3). The LCN byte is loaded into the PSI write buffer 302-12 in response to signial PAODV10 being forced to a binary ONE by the processor PSI circuits. The 55 write buffer contents are loaded into the A register when signal CDPTA10 is forced high by the control circuits 302-70. Thereafter, the control circuits 302-70 force in succession signals CDATB10, CDBTC10 and CDCTD10 to binary ONES.

As seen from Figure 6a, during the transfer interval, the read only store tests the contents of the C register for arrival of the LCN byte by executing a fast branch

type microinstruction AO700. When the C register is loaded, the store stops testing and then advances the next microinstruction AO600 for storing the LCN byte in one of the general registers (i.e. GPRO). Thereafter, the processor 300 executes another microinstruction AO850 which transfers a bit representation of the LCN byte stored in GPRO to the device adapter port register via the ALU. At the same time, the LCN byte is transferred via the ALU and stored in the RWS device port register.

It is assumed that the LCN byte relates to a command of a channel program previously activated. Therefore, the device is assumed to have been "seized" and bit status obtained therefrom. Accordingly, the flow chart of Figure 6a omits such details.

The processor hardware decrements the PSI counter by I via signal STI each time it receives a byte; the microprogram control store waits until the next byte is loaded into the C register. By executing a similar sequence of operations, the processor 300 stores the command code byte in another one of the general purpose registers (i.e. GPR9). The processor hardware terminates the routine sequence upon receipt of the third byte which is a flag byte. This byte is loaded into another general purpose register. At this time, the processor hardware will have decremented the PSI counter to ZERO which signals the end of the transfer.

The processor 300 enters a command 100 decode sequence wherein it examines the bits of the command code. That is, it executes a microinstruction, designated CMDEC AO700, in which it fetches the command code from GPR9 and loads it 105 into the ALU latches. Then during a succession of branch microinstructions, the processor tests the command code a bit or a number of bits at a time and branches on the results of the test to the start of an 110 appropriate microprogram routine for executing the command. The bits are tested sequentially so as to more easily detect the encountering of so-called "don't care" bits (i.e. those not required selecting a routine). 115

It is assumed that the I/O operation specified by the channel program is a search operation in which the bytes of the key field portion of the record of Figure 5 are going to be read from the mass storage 120 device and compared with the search argument bytes the processor receives from the IOC. Referring to Figure 6b, it is seen that the read only store causes the processor to perform a test to determine 125 whether it is "oriented" with respect to the record being read. In greater detail, the processor had previously stored orientation information in a general purpose register

indicating the relative position of the mass storage media and the format of the record being read from a track. It tests this information (i.e. a particular bit) to determine when an operation specified by the command is to be executed. As the different fields within a record are being read, the bits of the orientation information of a control "work byte" stored in the

general register are updated.

From Figures 5a and 5b, it is seen that the start of a track is indicated by an index mark. The selected mass storage device signals the adapter that it has sensed the start of the track by forcing line IDX to a binary ONE. The adapter in turn signals the processor which sets a first bit in the control work byte to a binary ONE indicating the receipt of an index mark signal. It is the state of this bit which is tested by having the read only store read out a branch type microinstruction AO300. In the event that this bit is not set to a binary ONE, the processor branches to another microprogram routine beginning with microinstruction AO100 to fetch a count field which indicates the position of the media relative to the record being

written. The next test the processor makes is to determine whether the head is in the header to key gap which means that the next field is a key field. It does this by executing another branch type microinstruction A1000: Assuming that the control word byte contained in the same general register indicates that the read/write head is in the header-key gap, the results of the tests made on the state of another bit within the control byte stored in the general register will be positive. The read only store sequences to the next location where it reads out another microinstruction BO300 which fetches the contents of GPR10 and tests the state of bit 6 to determine whether this is a first pass indicating that the processor has not searched for a key of a record previously in response to this channel command. Since in this example,

50 this is the first pass (i.e. bit 6 is normally a binary ZERO) the read only store then sequences to microinstruction BO600 as indicated in Figure 6b.

The processor reads out an I/O type microinstruction BO600 having the format of the top instruction of Figure 4e. It is this microinstruction which the processor uses to set up the hardware paths for the first pass of a search key operation. The I/O microinstruction sub op code field is coded "00" to specify the loading of the PSI counter from the read write store local register which normally contains the key length information obtained from the header portion of the record being read. The data counter will have been loaded from a previous command because it was previously assumed that the test of being oriented was positive.

The PSI sequence flip-flops field of the I/O microinstruction BO600 is set to the code "1001" so to request data from the IOC and signal the IOC to terminate transfer with the last byte. The count field is all zeros and the trap count field is set to "01" indicating that the processor is to disregard the first byte of key field of the record since it is a sync byte signalling the start of a field. The next field, MSCSEQ flip-flops, of microinstruction BO600 is coded as "0101" which designates a search

first pass function.

When the microinstruction BO600 is read out into the read only memory local register, it is decoded by the sequence decoder and sets the appropriate control and sequence flip-flops to binary ONES. That is, the first pass (CQFPF) flip-flop 308-1, the read/write active (CQRWA), flip-flop 308-2 and search CQSHO flipflop 308-3 are all switched to binary ONES. The transfer out (CQTXO) flip-flop 308-5 remains a binary ZERO. Also, transfer in signal CQTX110 is a binary ZERO which places the buffer registers in their static states. The other flip-flops of Figure 3c remain in their binary ZERO states. The trap flip-flops 308-101 and 308—102 of Figure 3d are set to a count of "01". The compare cycle CQCMP flip-flop 308-100 is switched to a binary ONE when the search flip-flop switches to a binary ONE. This flip-flop enables the ALU Result test and Storage Circuits 316-30 (see Figure 3i) for storage of the search results during each byte comparison (i.e. enables signal CACMT10 to be forced to a binary ONE when both the C and D registers store bytes-signal CACMT1B=1).

The search COSHO flip-flop when in a 110 binary ONE state conditions the logic circuits of Figure 3H to enable the RWS memory to store the bytes in the appropriate locations as they are being transferred from the IOC and the device. 115 The first pass/format CQFPF flip-flop when a binary ONE conditions the buffer control circuits to have registers A, B and C transfer in bytes from the PSI control rather than from the RWS memory. The flip-flops CQFPF and CQRWA, both binary ONES, are going to couple the RWS memory 306-2 to the C register thereby allowing the bytes received from the IOC to be written into the RWS memory. Also, the 125 CQFPF flip-flop establishes a path between the D register and RWS memory 306—2. These paths enable the writing of the search argument bytes from the IOC and the key field bytes read from the mass storage 130

90

device into the RWS memory 306-2 to take place concurrently.

As seen from Figure 6b, the processor 300 loads the appropriate starting address into the RWS address register from the read only store by executing a RWS microinstruction designated as BO700. Next, the processor reads out a branch type microinstruction which when decoded tests whether the command has arrived on time from the IOC (i.e. whether the read/write head is still in the header-key gap indicating that the command is not too late to operate on the field indicated). Assuming that is the case, the test "chaining slip" will be in the negative (i.e. gap counter zero signal CCGCZ10) and the processor 300 now begins to set up the device (see Figure 3k). As seen from Figure 6b, the processor reads out microinstructions starting with a microinstruction CO200. Although not shown, this is done when the gap counter has been decremented to ZERO. The first logic type microinstruction (i.e. see Figure 4g), when read out and decoded, causes a read command specified by the constant field to be loaded into the device command register 310-4. Another logic type microinstruction of the same type causes a command to be loaded into the adapter command register 310-6 which causes the adapter 310 to force the DCS line to a binary ONE signalling the device of the command. Additionally, the adapter 310 in response to the command is operative to send bytes via the read buffer 310-32 after it has sensed having read the required preliminary control information, as for example, a particular start pattern. 40

Next, the processor 300 reads out a branch type microinstruction CO500 which when decoded again tests the state of bit 6 of the flag byte contents of GPR10. Since this bit is set to a binary ZERO, the read only store sequences the microinstruction CO800 wherein it sets bit 6 of the flag byte in GPR10 to a binary ONE as shown in Figure 6b. Next, it reads out a logic type microinstruction (F=1) CO900 which when decoded by the sequence decoder sets up the final paths to enable the ALU section to compare the byte contents of the C and D registers. That is, the B operand and A operand fields of the logic microinstruction are coded to have stored in the MUX address stores 314-21 and 314-22 coded signals which condition the B op MUX 314-22 and A op MUX 314-24 respectively to apply to the main and auxiliary ALU's C register and D register contents as operands. This completes the connection of the comparison path. Also, the signals condition the ALU to force the equal signal CAEQA10 to a binary ONE by setting the mode signals M0 to M3 to specify a result f=1. This in turn switches the equal store flip-flop 316-300 to a binary ONE in readiness for the search.

At this time, the different groups of buffer registers are connected to shift bytes in the proper direction, the PSI interface is conditioned to accept bytes from the IOC, the device has been given a command, the adapter is conditioned to receive bytes from the device and the ALU section is conditioned to compare the bytes from the designated sources. Also, the counters have been set to the appropriate counts. The PSI counter has been set to a count corresponding to key length and thereafter is decremented automatically upon receipt of each byte from the IOC. The data counter has been set to an appropriate count (i.e. key length included in count field) and is also decremented automatically as each byte is received from the device.

At this time, the firmware setup of hardware is complete and the processor 300 is placed under the control of the hardware. That is, all transfers of bytes take place independently of the read only storage and thus are free of any processing delays. This can be seen from an examination of the flow chart of Figure 6b. The read only store enters an idle loop which includes the two branch type microinstructions designated as C1010 and C1150. During the transfer operation, the read only store reads out a FCB microinstruction which when decoded tests the state of the end of command CBEOC flip-flop 304-300 of Figure 3f (i.e. test input 1 of circuit 304—284 of Figure 3f). When the CBEOC flip-flop is set to a binary ONE that signals the firmware that the transfer operation is complete. When the test is positive (CBEOC10=1), the read only store breaks its idling and again assumes control by sequencing to microinstruction C1300 whereafter it stores the results of the search key operation as described herein. Also, by another FCB microinstruction C1150, the processor 300 tests for the end of track signaled by the device sensing of an index mark which in turn forces signal AIIDT00 to a binary ZERO. Until one of these signals is forced to the binary ONE state, the processor 300 continues idling through the two microinstruction loop. During the idling, each time a byte is stored in the C and D registers, the circuits of block 316-30 force compare time signal CACMT10 to a binary ONE. If both bytes compare the ALU 316-2 forces signal CAEQA10 to a binary ONE which in turn holds slip-slop 316-300 in its binary ONE state. If at any compare interval, the bytes do not compare the ALU forces signal CAEQA(0 to a binary ZERO. This forces the hold signal 130 . 2

CAEQS1H to a binary ZERO which resets the flip-flop 310—300 to a binary ZERO. At that time, sigal CAAEB10 is also forced to a binary ZERO. Thus a first non comparison will reset the equal compare flip-flop 310—300 and this flip-flop remains in that state until another microinstruction is executed. This occurs only after the

completion of the operation.

From Figure 3f, it is seen that the end of command flip-flop 304-300 is set to a binary ONE when the data counter has been decremented to a count of ZERO (i.e. signal CCDCZ1A=1) and all of the registers (i.e. A, B, C, D, E and F registers) are empty (i.e. signal CDDBE10=1). Assuming that the last byte has been transferred and data counter has been decremented to ZERO, the read only store upon read out and decoding of the FCB microinstruction Cl010 sequences to the branch type microinstruction 1300 which tests to determine whether the EOC flip-flop 304-300 was set to a binary ONE because it was the end of the transfer operation (i.e. data counter was decremented to ZERO) or because an error was detected by the adapter 310 (i.e. signal AEERR10=1). Assuming no error, the read only store sequences to microinstruction DO400 which is a first microinstruction of a routine for evaluating the comparison results. Either one of none of the flip-flops 316—300 and 316—310 of result test and storage 316—30 of Figure 3h will be set to a binary ONE. Assuming that there was a comparison, then the equal CAEQS flipflop 316-300 is a binary ONE. After the setting of the status bits, reflecting the results of the key search, the processor executes a branch type microinstruction which returns the processor to microinstruction DO100. This microinstruction microinstruction tests the results and sets an indicator. The processor 300 sequences to microinstruction D400 to test for whether there was a read error. Assuming there is no read error, this means there was a true comparison and the read only store 50 now sequences to a microinstruction routine beginning with microinstruction H100 which loads an appropriate code into a general purpose register (GPR8) used in signalling the IOC. After appropriate signal 55 exchanges over the PSI, the IOC is caused to send the next command to be executed which could for example be a command to perform an operation on the data field of the record whose key compare with that

60 supplied by the IOC.

Figure 6c shows the operations performed by the processor while it awaits the next command from the IOC. It is during this time that the read/write head of the mass storage device is passing through

the key/data gap of the record (see Figure 5b). For example, the processor fetches and decodes microinstruction which loads the data counter with a count corresponding to the data length field included in the count field associated with the key field of the record just searched. This is done in anticipation that the next command will specify an operation upon the data field. The routine in the Figure is called "process end of file" (PREOF). When it loads the data counter it also checks for a data length of ZERO. It it is ZERO, this indicates that this is an end of file record. Assuming no end of file, the read only store sequences to microinstruction AO100 which sends the code stored in the general purpose register to the IOC, also a part of the request for the next command. The read only store then returns to a previous routine in which it updates the contents of an address register location in the RWS memory to correspond to the identifier of the last record searched successfully. Then the read only store references the search routine for a last time to set up the PSI controls section to accept the next command following which it finally branches to the command code routine CMDEC to decode the next command code.

It is seen that the microprogrammable processor includes hardware control sequencing apparatus in addition to microprogram control store. The control store generates signals which condition the hardware sequencing apparatus to set up appropriate hardware paths for executing a particular command. Following the set up, the microprogram control store transfers control to the hardware sequencing apparatus which enables the data transfer to proceed at maximum speed independent of the operating or cycling speed of the control store.

In the particular operation described above, the control store idled until the hardware sequencing apparatus signaled the completion of the transfer. Of course, the ALU was involved in comparing bytes from two sources as required by the search operation. It will be appreciated that in the case of other types of operations, the control store instead of idling could perform certain operations unrelated to the transfer of bytes. For example, in response to arithmetic microinstructions read out of the control store, the ALU can compute a variable length gap as part of a write command. That is, in some cases a disk is formatted to have a variable length gap based on the length of the data field being written. Thus, while the data transfer takes place, the ALU in the processor of the

/0

75

80

85

90

95

100

105

110

113

120

present invention computes the gap by adding the data length and key length and take a percentage of the sum. Similar calculations can be performed as part of a read command where a variable length gap is calculated in anticipation of another format specified by a write command chained to the read command being executed.

Additionally, the control store can executed.

perform operations which modify the contents of different address registers within the processor such as updating certain registers to indicate the address of a "last data field processed". These operations would take place either before the control store enters an idle loop condition or during the data transfer as required for the particular command being executed.

20 .

#### Appendix

### Glossary of Terms

|     |                      | Glossary of Terms                                          |
|-----|----------------------|------------------------------------------------------------|
|     | Term                 | Definition                                                 |
|     | Alternate Track      | An alternate track is one which contains data that has     |
| 25  | _                    | been repositioned from a defecting primary track.          |
|     | Byte                 | The basic unit of information handled by the Mass          |
|     |                      | Storage Subsystem (MSS). A byte is made up of 8            |
|     |                      | information bits each of which can be set to logical       |
|     |                      | ONE (ON) or to logical ZERO (OFF), to represent            |
| 30  |                      | any one of 256 combinations. Bit 0 is defined as the       |
|     |                      | leftmost or most significant bit and bit 7 as the          |
|     |                      | rightmost or least significant bit.                        |
|     | Byte Wide Path       | Bytes of information transferred across the interface      |
|     | •                    | consist of eight information bits plus one odd parity      |
| 35  | •                    | bit. The information is arranged so that bit 0 is          |
|     |                      | always the most significant bit. The parity bit is ONE     |
|     |                      | if the number of ONE bits in the corresponding eight       |
|     |                      | information bits is even, ZERO if the number of            |
|     |                      |                                                            |
| 40  |                      | ONE bits is odd, i.e. odd parity is generated on the       |
|     | Central Processor    | eight information bits.                                    |
|     | Complex (CPC)        | The Central Processor Complex consists of those units      |
|     | complex (Cl C)       | used for addressing main storage, for retrieving or        |
|     | •                    | storing information, for arithmetic and logic              |
| 45  |                      | processing of data, for sequencing instructions in the     |
|     |                      | desired order, and for initiating the communication        |
|     |                      | between storage and external devices. The main             |
|     |                      | units of the CPC are the Central processor unit            |
|     |                      | (CPU), the main store and the Input/Output                 |
| 50  | Channel Command      | controller (IOC).                                          |
| 50  | Entry (CCE)          | The Channel Command Entry is the elementary building       |
|     | Ziniy (CCL)          | block of channel programs. It consists of two CCWs         |
|     |                      | and may contain a command, flag, count                     |
|     |                      | information, branching information, key or buffer          |
| 55  |                      | addresses and a command extension field. The               |
| ,,, | Channel Control      | address of a CCE is the address of its first CCW.          |
|     | Word (CCW)           | A CCW is a 32-bit (4 byte) word that is a subdivision of a |
|     |                      | CCE.                                                       |
|     | Channel Program (CP) | A CP is a complete set of instructions and addressing      |
| 60  |                      | information to carry out an I/O operation. It is           |
| 00  | Carra Field          | composed of CCEs which are made up of CCWs.                |
|     | Count Field          | The first field of each record. The Count field describes  |
|     | Cualia Chash Cada    | the Key and Data fields of the same record.                |
|     | Cyclic Check Code    | A Cyclic check code is used for error detection when       |
| 65  |                      | information is stored into and retrieved from a field.     |
| 05  |                      | When data is recorded, a cyclic check code is              |
|     |                      | arithmetically coded from the information to be            |
|     |                      | placed in the field and is recorded as part of the field.  |
|     |                      | When a field is read from the storage medium, the          |
| 70  |                      | cyclic check code is recomputed and compared to            |
| 70  |                      | the cyclic check code recorded as part of the field. If    |
|     |                      | the comparison is unsuccessful an error condition is       |
|     |                      | indicated. On certain devices, the cyclic check code       |
| •   |                      | is replaced by an error detection and correction           |
|     |                      | code.                                                      |
|     |                      | STK                                                        |

| ,  |                      | 1,470,700                                                 |
|----|----------------------|-----------------------------------------------------------|
|    |                      | Appendix Glossary of Terms                                |
|    | Term                 | Definition                                                |
|    | Cylinder             | All tracks which are qualible for days and f              |
| 5  |                      | All tracks which are available for data transfer without  |
|    |                      | additional movement of the access mechanism. Each         |
|    |                      | cylinder in a storage device is identified by a unique    |
|    |                      | cylinder address and designates a specific position of    |
|    |                      | the set of Read/Write heads on each surface of the        |
|    | •                    | device.                                                   |
| 10 | Data Field           |                                                           |
|    |                      | The field which contains the information identified by    |
|    |                      | the Count and Key fields of the record. The Data          |
|    |                      | lield is recorded on the storage media immediately        |
|    |                      | tollowing the Ney Held: If a Key Held does not eviet      |
|    |                      | the Data field follows the Count field                    |
| 15 | Defective Track      | A defective track is a track from which recorded          |
|    |                      | information cannot be soliable asset fecolded             |
|    |                      | information cannot be reliably recovered. This            |
|    |                      | condition is normally a result of a surface               |
|    |                      | imperiection and localized to a small nortion of the      |
|    | <b></b>              | Hack Sullace.                                             |
| 20 | Field                | A group of related contiguous bytes. Four types of fields |
|    |                      | are defined within the MSP: a Home Address field,         |
|    |                      | a Count field a Kan field and Tome Address field,         |
|    |                      | a Count field, a Key field, and a Data field (defined     |
|    | Home Address Field   | iii tiiis Appendix).                                      |
| 36 | Home Address Field   | One Home Address field on each track follows the Index    |
| 25 |                      | Mark, identifies the physical location of the track       |
|    |                      | within the storage device, and contains information       |
|    |                      | describing the condition of the track. The first          |
|    | •                    | second recorded on the track. The light                   |
|    |                      | record recorded on the track starts at Index Mark         |
| 30 | Index Mark           | when a Home Address field does not exist.                 |
| 50 |                      | A mark which signals the beginning of a track. All tracks |
|    |                      | III a Cyllinger are synchronized by the same Index        |
|    | T 10                 | Mark.                                                     |
|    | Input/Output         | An IOC is the mainframe hardware/firmware involved        |
|    | Controller (IOC)     | during the execution of a channel arrange involved        |
| 35 |                      | during the execution of a channel program. It may         |
|    |                      | control several physical channels. In this document       |
|    |                      | the unit which connects to the mainframe side of the      |
|    | ·                    | P31 is referred to as the IOC. Other terms that have      |
|    |                      | been used with the same meaning are Central               |
|    |                      | Processor Unit, Channel Control Unit, Channel, I/O        |
| 40 |                      | Processor, etc.                                           |
|    | IOC Instruction      | An IOC instruction is an instruction and Co.              |
|    |                      | An IOC instruction is an instruction sent from the IOC to |
|    |                      | the PCU. This instruction is not part of the channel      |
|    | •                    | program, but may be related to channel program            |
|    | V 50 11              | activity (e.g., disconnect).                              |
| 45 | Key Field            | The Key field allows searching of identifying information |
|    |                      | about a record. The identifying information is stored     |
|    |                      | within the Key field 15                                   |
|    | •                    | within the Key field. If present, the Key field           |
|    | Line States          | immediately follows the record Count field.               |
| 50 | Eine States          | An interface signal line in the ONE state, or high, is    |
| 50 |                      | understood to be in the logical TRUE state: a line in     |
|    |                      | the ZERO state, or low, is understood to be in the        |
|    |                      | logical FALSE state. The rise of a line will imply a      |
|    |                      | transition from the EALCE to the There                    |
|    |                      | transition from the FALSE to the TRUE state while         |
| 55 |                      | the fall of a line will imply the transition from the     |
| 55 | Logical Chandel (LC) | I RUE to the FALSE state.                                 |
|    | Logical Channel (LC) | The input/output system is based on the concept of        |
|    |                      | logical channels. The access path from the CPU to         |
|    |                      | the device for the purpose of executing an I/O            |
|    |                      | Operation is termed a channel The share it                |
| 60 |                      | operation is termed a channel. The channel consists       |
|    | ·                    | of IOC facilities, a hardware link between the IOC        |
|    |                      | and PCU identified as the physical channel and a          |
|    | •                    | logical channel. The logical channel in its most          |
|    |                      | elementary form is the collection of facilities in a      |
|    |                      | peripheral control unit subsystem required to             |
| 65 |                      | execute an I/O operation such as a read, write, etc.      |
| •  |                      | ordered and o operation such as a read, write, etc.       |
|    | •                    | ·                                                         |

|    | _                                  | Appendix Glossary of Terms Definition                                                                                                                                                                                                                               |
|----|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | Term . Logical Channel (LC) (cont) | An I/O operation is defined by a channel program. A logical channel can only have one channel program active on it at one time. Logical channel numbers are used by the channel for ordering the storage of parameters required to maintain a number of             |
| 10 |                                    | channel programs operating simultaneously. As such, software visibility of an I/O operation is through a logical channel. (From a software point-of-view, devices are allocated an IOC number, a physical channel number and a logical channel                      |
| 15 |                                    | number for selection purposes). A logical channel number explicitly identifies a device. A channel program is restricted to one device. Devices are                                                                                                                 |
|    |                                    | assigned logical channel numbers at system configuration time or when the device is added to                                                                                                                                                                        |
| 20 |                                    | the system. There may be more than one logical channel per device. A logical channel is considered active from the time an Initiate New Channel Program service code is received by the IOC until it                                                                |
| 25 | Magazine                           | is terminated by an event notification to software.  A group of tracks and/or cylinders which may be individually removable. If several magazines exist in a device, only one magazine at a time may be                                                             |
|    | Multiple Track<br>Operation        | positioned with the read/write erase mechanism.  The ability of the MSS, when provided with certain I/O commands in certain modes, to automatically switch                                                                                                          |
| 30 | •                                  | to successive tracks in the same cylinder and to continue the operation on the new track.                                                                                                                                                                           |
|    | Peripheral Device                  | A peripheral device is a single addressable data source or sink. The peripheral device may be a unit controlling                                                                                                                                                    |
| 35 | Peripheral Processor               | a physical medium (e.g. disk drive, tape drive) or an electronic medium (e.g., communications channel).  A PP (e.g. mass storage processor (MSP)) is the unit connected on the peripheral side of the PSI which controls and operates the peripheral devices. Other |
| 40 |                                    | names with similar meanings are Peripheral Control Unit, Peripheral Controller, Microprogrammed Peripheral Controller (MPC), Multi-Line Controller                                                                                                                  |
|    | Peripheral Subsystem               | (MLC), etc.  A Peripheral subsystem (e.g. mass storage subsystem                                                                                                                                                                                                    |
| 45 |                                    | MSS) is comprised of those functional units existing outside of the central processing and main store facilities which are required to operate and control the peripheral devices in a system. A peripheral                                                         |
| 50 |                                    | subsystem may include one or more PSIs, one or more peripheral control units, and one or more peripheral devices.                                                                                                                                                   |
| 30 | Physical Channel                   | A physical channel is the hardware link between the IOC and the peripheral control unit. This hardware link consists of one PSI and the facilities at each end of the PSI dedicated to the PSI.                                                                     |
| 55 | Primary Track                      | A primary track is the original track on which data was stored.                                                                                                                                                                                                     |
|    | Read                               | Read indicates the direction of dialog flow (from the                                                                                                                                                                                                               |
| 60 | Record                             | PCU to the IOC), i.e. an input operation.  A group of related fields. A record consists of a Count field, a Key field which immediately follows its related Count field on the storage media, and a Data field which immediately follows its related Count          |
|    | •                                  | and Key sield. The length of the Key sield may be specified as zero, in which case a record consists of                                                                                                                                                             |
| 65 |                                    | only a Count and Data field.                                                                                                                                                                                                                                        |

# Appendix

|    |                                                                                                                                                              | Glossary of Terms                                                                                                                                                                                                                           |    |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|    | Term                                                                                                                                                         | Definition                                                                                                                                                                                                                                  |    |
| 5  | Record Overflow                                                                                                                                              | Record overflow is a capability which allows a logical-<br>record to be recorded on more than one track. Such<br>a record is known as an overflow record. A portion                                                                         |    |
| 10 |                                                                                                                                                              | of an overflow record that is written on one track is called a record segment. Most functions defined in the MSS treat the entire logical record as if it was a single physical record.                                                     |    |
|    | Record Segment<br>Service Code                                                                                                                               | A segment of an overflow record—see Record Overflow.  A service code is an eight-bit instruction (plus parity) transferred over the PSI from the PP to the IOC and                                                                          | •  |
| 15 |                                                                                                                                                              | used for defining subsequent information transfer over the interface as well as initiating activity in the IOC.                                                                                                                             |    |
| 20 | Track                                                                                                                                                        | One of the concentric recording areas on a disk surface.  Each track in a cylinder is identified by a unique track address which defines the particular                                                                                     |    |
| 20 | Write                                                                                                                                                        | Read/write head to be used in referencing the device.  Write indicates the direction of dialog flow (from the                                                                                                                               |    |
|    |                                                                                                                                                              | IOC to the PP), i.e., an output operation.                                                                                                                                                                                                  |    |
| 25 | WHAT WE CLAIM IS:— 1. A microprogrammed processor having a peripheral                                                                                        | predetermined ones of said control signals from said microprogram control means and subsystem wherein the data transfer microinstruction                                                                                                    | 65 |
|    | interface to which a central probe coupled and at least one dinterface to which an input/out                                                                 | cessor may sequence includes at a specified point levice level therein an input/output type                                                                                                                                                 |    |
| 30 | may be coupled, and operative<br>the operation of the input/outpuresponse to command signal                                                                  | to control bistable devices to predetermined states for at device in controlling the transfer of information                                                                                                                                | 70 |
| 35 | through the peripheral subsystem<br>and to transfer information be<br>peripheral subsystem interface<br>device level interface, the<br>processor comprising: | m interface etween the e and the peripheral  3. A processor according to Claim 2 wherein the input/output type microinstruction includes a sequence field coded to establish which ones of the bistable devices are to be switched to their | 75 |
| 40 | unitary microprogram contincluding storage means storing of microinstruction sequences each plurality of microinstruction control means responsive to a      | rol means binary ONE states for execution of the a plurality operation specified by the command code. ch having a 4. A processor according to any previous s. branch claim wherein the storage means is a read                              | 80 |
| 45 | code and other signals to cause means to branch among said and decoding means generating signals in response to the microid read out from the storage means  | sequences, claim wherein the microinstruction means enters an idle loop during transfer of data through the data transfer means and the                                                                                                     | 85 |
| 50 | bidirectional data transfe<br>coupled to the peripheral<br>interface and the device level inte                                                               | er means on the termination of the data transfer. subsystem 6. A processor according to claim 5 erface; and wherein, on interruption of the loop, a                                                                                         | 90 |
|    | sequence control means respons<br>control signals to generat<br>controlling the transfer of in                                                               | e signals the results of the information transfer.  7. A processor according to any previous                                                                                                                                                |    |
| 55 | signals from one of the interfact<br>the data transfer means to<br>interface at a rate independe<br>operating rate of the microprogra                        | the other includes a plurality of cycle control flip-                                                                                                                                                                                       | 95 |
| 60 | means when a microinstruction<br>for such data transfer is entered<br>2. A processor according to<br>wherein the sequence contr                              | sequence of various events in data transfer and l. condition the processor for the occurrence or claim 1 of the succeeding events in the data 10 of means transfer.                                                                         | 00 |
|    | includes a plurality of bistable connected to switch state in re                                                                                             | le devices 8. A processor according to any previous                                                                                                                                                                                         |    |

85

transfer means comprise a plurality of buffer registers and interconnection means therebetween controlled by the sequence control means to permit the transfer of information bytes between the buffer registers in any one of a plurality of different modes.

9. A processor according to claim 8 wherein the sequence control means includes a transfer-in flip-flop and a transfer-out flip-flop coupled to the interconnection means to establish the direction of transfer for first and second groups of the buffer registers in accordance with the states of the transfer flip-flops.

wherein the first group includes registers designated A, B and C and the second group includes registers designated D, E and F, the interconnection means being responsive to the ONE and ZERO states of the transfer-in flip-flop to cause the transfer of bytes from the C register to the A register or from the A register to the C register respectively, and responsive to the ONE and ZERO states of the transfer-out flip-flop to cause the transfer of bytes from the D register to the F register or from the F register to the D register respectively.

11. A processor according to claim 10 wherein signals corresponding to the states of said transfer-in and transfer-out flip-flops are used to define a plurality of submodes in accordance with the states of certain ones of the cycle control flip-flops.

12. A processor according to claim 11 wherein during a first submode, the sequence control means enables a transfer of information bytes into the processor from the peripheral subsystem interface and the device level interface through the first and second groups of registers respectively.

13. A processor according to any previous claim and including: arithmetic and logic processing means coupled to the device level interface and to the data transfer means; and, read/write storage means coupled to the arithmetic and logic

means and to the data transfer means, the sequence control means conditioning the arithmetic and logic processing means and the read/write storage means to perform sequences of operations required for processing and storage of said information signals respectively.

14. A processor according to claim 2 or any claim appendant thereto wherein the sequence control means includes a trap counter specifying the number of data bytes to be trapped during the execution of a command, and the input/output microinstruction includes a trap count field whose contents are set into the trap counter on execution of that microinstruction.

15. A processor according to claim 2 or any claim appendant thereto wherein different sequences of microinstructions are entered in response to read, write, and search commands, each of such sequences including an input/output type microinstruction.

16. A processor according to claim 2 or any claim appendant thereto including a counter for storing a number of information signal bytes to be transferred, and wherein the counter is loaded in response to an input/output type microinstruction.

17. A processor according to claim 16 including a plurality of said counters, and wherein each input/output type microinstruction which causes the loading of said counters specifies which counter is to be loaded and the source of the count to be loaded.

18. A processor according to claim 17 when appendant to claim 13 wherein the source of the count to be loaded is either the microprogram control means or the read/write storage means.

19. A microprogrammed peripheral processor substantially as herein described with reference to the accompanying drawings.

M. G. HARMAN. Chartered Patent Agent.

Printed for Her Majesty's Stationery Office, by the Courier Press, Learnington Spa, 1978 Published by The Patent Office, 25 Southampton Buildings, London, WC2A 1AY, from which copies may be obtained.

1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 1



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 2



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 3



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 4



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 5



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 6



Fig. 3d.

1496 780 COMPLETE SPECIFICATION 23 SHEETS This drawing is a reproduction of the Original on a reduced scale. SHEET 7



Fig. 3e.

1 496780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 8



1 496780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 9



1 496780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 10



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 11



1 496 780 COMPLETE SPECIFICATION
23 SHEETS
This drawing is a reproduction of the Original on a reduced scale.
SHEET 12



1496780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 13



1496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 14



1 496 7.80 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 15



1496 780 COMPL 23 SHEETS This draw the Origin

COMPLETE SPECIFICATION

This drawing is a reproduction of the Original on a reduced scale.

SHEET 16





Frig. 4b.

### 1 496 780 23 SHEETS

#### COMPLETE SPECIFICATION

This drawing is a reproduction of the Original on a reduced scale.

SHEET 17





1496780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 18



1496780 COMPLETE SPECIFICATION
23 SHEETS
This drawing is a reproduction of the Original on a reduced scale.
SHEET 19



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 20



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 21



1 496 780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 22



1496780 COMPLETE SPECIFICATION
23 SHEETS This drawing is a reproduction of the Original on a reduced scale.
SHEET 23



# This Page is Inserted by IFW Indexing and Scanning Operations and is not part of the Official Record

### **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

| ☑ BLACK BORDERS                                       |
|-------------------------------------------------------|
| ☐ IMAGE CUT OFF AT TOP, BOTTOM OR SIDES               |
| ☐ FADED TEXT OR DRAWING                               |
| ☐ BLURRED OR ILLEGIBLE TEXT OR DRAWING                |
| ☐ SKEWED/SLANTED IMAGES                               |
| ☐ COLOR OR BLACK AND WHITE PHOTOGRAPHS                |
| GRAY SCALE DOCUMENTS                                  |
| ☑ LINES OR MARKS ON ORIGINAL DOCUMENT                 |
| REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY |
| OTHER.                                                |

## IMAGES ARE BEST AVAILABLE COPY.

As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.

THIS PAGE BLANK (USPTO)